Преобразование метки времени MySQL в эпоху времени в Python - PullRequest
7 голосов
/ 22 сентября 2008

Преобразование метки времени mysql в эпоху в python - есть ли простой способ сделать это?

Ответы [ 4 ]

27 голосов
/ 22 сентября 2008

Почему бы не позволить MySQL выполнять тяжелую работу?

select unix_timestamp(fieldname) from tablename;
9 голосов
/ 09 марта 2010

преобразование времени MySQL в эпоху:

>>> import time
>>> import calendar
>>> mysql_time = "2010-01-02 03:04:05"
>>> mysql_time_struct = time.strptime(mysql_time, '%Y-%m-%d %H:%M:%S')
>>> print mysql_time_struct
(2010, 1, 2, 3, 4, 5, 5, 2, -1)
>>> mysql_time_epoch = calendar.timegm(mysql_time_struct)
>>> print mysql_time_epoch
1262401445

преобразование эпохи во что-то, что MySQL может использовать:

>>> import time
>>> time_epoch = time.time()
>>> print time_epoch
1268121070.7
>>> time_struct = time.gmtime(time_epoch)
>>> print time_struct
(2010, 3, 9, 7, 51, 10, 1, 68, 0)
>>> time_formatted = time.strftime('%Y-%m-%d %H:%M:%S', time_struct)
>>> print time_formatted
2010-03-09 07:51:10
4 голосов
/ 23 сентября 2008

Если по какой-то причине вы не хотите, чтобы MySQL выполнял эту работу, вы можете сделать это в Python достаточно легко. Когда вы возвращаете столбец datetime из MySQLdb, вы получаете объект datetime.datetime из Python. Чтобы преобразовать один из них, вы можете использовать time.mktime. Например:

import time
# Connecting to database skipped (also closing connection later)
c.execute("SELECT my_datetime_field FROM my_table")
d = c.fetchone()[0]
print time.mktime(d.timetuple())
1 голос
/ 24 сентября 2008

Я использую что-то вроде следующего, чтобы получить секунды с начала эпохи (UTC) от даты MySQL (местное время):

calendar.timegm(
   time.gmtime(
      time.mktime(
         time.strptime(t, 
                       "%Y-%m-%d %H:%M:%S"))))

Больше информации в этом вопросе: Как мне преобразовать местное время в UTC в Python?

...