views:

97

answers:

2

I am trying to convert a string timestamp into a proper datetime object. The problem I am having is that there is a timezone offset and everything I am doing doesn't seem to work.

Ultimately I want to convert the string timestamp into a datetime object in my machines timezone.

# string timestamp     
date = u"Fri, 16 Jul 2010 07:08:23 -0700"
+1  A: 

The dateutil package is handy for parsing date/times:

In [10]: date = u"Fri, 16 Jul 2010 07:08:23 -0700"

In [11]: from dateutil.parser import parse

In [12]: parse(date)
Out[12]: datetime.datetime(2010, 7, 16, 7, 8, 23, tzinfo=tzoffset(None, -25200))
ars
how do I take this and turn it into a time representation that matches my current timezone?and thanks for that btw :)
alfredo
Glad to help. You can use the `astimezone` method of the datetime object that's returned by parse. See this question for detail: http://stackoverflow.com/questions/79797/how-do-i-convert-local-time-to-utc-in-python
ars
+1  A: 

It looks like datetime.datetime.strptime(d, '%a, %d %b %Y %H:%M:%S %z') should work, but according to this bug report there are issues with the %z processing. So you'll probably have to handle the timezone on your own:

import datetime

d = u"Fri, 16 Jul 2010 07:08:23 -0700"

d, tz_info = d[:-5], d[-5:]
neg, hours, minutes = tz_info[0], int(tz_info[1:3]), int(tz_info[3:])
if neg == '-':
    hours, minutes = hours * -1, minutes * -1

d = datetime.datetime.strptime(d, '%a, %d %b %Y %H:%M:%S ')
print d
print d + datetime.timedelta(hours = hours, minutes = minutes)
Chris B.