UTC "timezone" causing brain explosions
Ben Finney
ben+python at benfinney.id.au
Wed Jan 29 17:44:58 EST 2014
Skip Montanaro <skip at pobox.com> writes:
> Following up on my earlier note about UTC v. GMT, I am having some
> trouble grokking attempts to convert a datetime into UTC.
For what it's worth, you're not alone. Time zones are a hairy beast to
manage, made all the more difficult because national politicians
continually fiddle with them which means they can't just be a built-in
part of the Python standard library.
> Consider these three values:
>
> >>> import pytz
> >>> UTC = pytz.timezone("UTC")
> >>> UTC
> <UTC>
> >>> LOCAL_TZ = pytz.timezone("America/Chicago")
> >>> LOCAL_TZ
> <DstTzInfo 'America/Chicago' CST-1 day, 18:00:00 STD>
> >>> now = datetime.datetime.now()
> >>> now
> datetime.datetime(2014, 1, 29, 15, 39, 35, 263666)
>
> All well and good, right?
Not really :-) You avoid the pain if you never create naive datetime
values in the first place.
Instead, specify the timezone for the value you're creating::
>>> now = datetime.datetime.now(tz=LOCAL_TZ)
>>> now
datetime.datetime(2014, 1, 29, 16, 35, 7, 900526, tzinfo=<DstTzInfo 'America/Chicago' CST-1 day, 18:00:00 STD>)
That way the value will respond correctly to requests to convert it to
whatever timezone you specify::
>>> MELBOURNE = pytz.timezone("Australia/Melbourne")
>>> now.astimezone(MELBOURNE)
datetime.datetime(2014, 1, 30, 9, 35, 7, 900526, tzinfo=<DstTzInfo 'Australia/Melbourne' EST+11:00:00 DST>)
>>> now.astimezone(UTC)
datetime.datetime(2014, 1, 29, 22, 35, 7, 900526, tzinfo=<UTC>)
>>> now.astimezone(LOCAL_TZ)
datetime.datetime(2014, 1, 29, 16, 35, 7, 900526, tzinfo=<DstTzInfo 'America/Chicago' CST-1 day, 18:00:00 STD>)
--
\ “We tend to scoff at the beliefs of the ancients. But we can't |
`\ scoff at them personally, to their faces, and this is what |
_o__) annoys me.” —Jack Handey |
Ben Finney
More information about the Python-list
mailing list