py> from dateutil.tz import gettz
py> from datetime import datetime
py> new_york = gettz('America/New York')
py> los_angeles = gettz('America/Los Angeles')
py> minsk = gettz('Europe/Minsk')
py> fmt = "%Y-%m-%d %H:%M%z"
py> datetime.now(new_york).strftime(fmt)
'2012-02-03 01:51-0500'
py> datetime.now(los_angeles).strftime(fmt)
'2012-02-02 22:51-0800'
py> datetime.now(los_angeles).astimezone(minsk).strftime(fmt)
'2012-02-03 09:51+0300'
For me, the most annoying thing about Python is that out of the box, AFAICT, you cannot get a TZ-aware datetime. In fact, while tzinfo is part of the standard library, I don't know of any included solution for making TZ-aware datetime, short of writing your own subclasses for each timezone.EDIT: datetime.utcnow() is TZ-aware, I meant any other timezone.
That's because the stdlib would have to get updated every 3-6 months, which it is not. Hence delegating to e.g. pytz for timezones provision.
> I don't know of any included solution for making TZ-aware datetime, short of writing your own subclasses for each timezone.
There isn't indeed, because there can't be an stdlib-provided way to do this which is actually correct.
It also contains tzinfo implementations that read timezone definitions from a system-wide copy of the Olson database (for most POSIX OSs) or the registry (for Windows-based OSs). These could also be added to the standard library without requiring regular Python updates, because the OS's usual timezone update system will take care of things.
Perhaps the stdlib can't possibly solve timezone issues in all possible cases, but it could be a lot more useful than it currently is.
I think this project still fills a nice niche. datetime.now(los_angeles).astimezone(minsk).strftime(fmt) is long enough that you're going to have to find the StackOverflow thread in question to implement this, and maybe go to the stdlib. This library makes that a lot less painful.
If you go to the source, you'll see how tiny it is! It's nowhere near the complexity of dateutil. I'd love to see some of dateutil's darker corners wrapped into this library.
We thought this might be an issue for things like emailing purchase receipts to people since that is something that can't just be 'rendered' on the client, but we ended up just asking ourselves "What would amazon do?" and looked at an emailed Amazon receipt.
You will notice that there isn't a single time in the receipt other than when the email was sent. Looked at a receipt from Apple. Same thing. Problem solved by just removing the timestamp from the receipt.
Thought that was an interesting tidbit that I hadn't thought of before.
This is the JS library I used and am pretty happy with: http://momentjs.com/
I recently was evaluating JS and Python for handling time in my app. The goal was not to localize to a specific timezone for the client, but rather to inform the client of where in the world a current time is.
I ended up picking the Python backend solution because it was easier to reason about with the more abstract `datetime` primitives.
You can accept user input as (year, month, day, hour, minute, second), convert to a common timezone, and store as seconds since epoch. To display, convert back to the common timezone, but omit the timezone identifier. This is useful for events which are local for the user, since they don't care about their own timezone.
See the iCalendar spec,
They are used to represent the same hour, minute, and second value regardless of which time zone is currently being observed. For example, an event can be defined that indicates that an individual will be busy from 11:00 AM to 1:00 PM every day, no matter which time zone the person is in. In these cases, a local time can be specified.
The date and time representations may appear in proximity to each other, often separated by a space or sometimes by other characters. In these cases they occupy two separate fields in a data system, rather than a single combined representation. This is usually done for human readability. Unlike the previous examples, "2007-04-05 14:30" is considered two separate, but acceptable, representations—one for date and the other for time. It is then left to the reader to interpret the two separate representations as meaning a single time point based on the context.
http://en.wikipedia.org/wiki/ISO_8601
That said, I prefer the "separated date and time" representation myself.
Btw, Django 1.4 (now alpha) is getting timezone support [1] and its django.utils.timezones [2] features similar functionaliy.
[1] https://docs.djangoproject.com/en/dev/topics/i18n/timezones/...
[2] https://github.com/django/django/blob/master/django/utils/ti...
>>> datetime.datetime.now() - datetime.timedelta(days=1)
datetime.datetime(2012, 2, 1, 23, 33, 30, 591993)Just creating timezone aware datetime objects is really too difficult with the standard library anyway. You need to install `pytz` or create your own `datetime.tzinfo` classes just to be able to represent timezones.
To top it off, if you have datetime objects with timezones and datetime objects without timezone information (*even created using utcfromtimezone()!), you can't compare them.
I can't remember for sure but I don't think you can subtract two dates and get a delta?