在python中将mysql时间戳转换为纪元时间 - 有没有简单的方法可以做到这一点?
Max
问问题
18628 次
4 回答
28
为什么不让 MySQL 做艰苦的工作呢?
select unix_timestamp(fieldname) from tablename;
于 2008-09-22T16:26:51.337 回答
9
将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
于 2010-03-09T07:51:59.440 回答
5
如果您出于某种原因不想让 MySQL 完成这项工作,那么您可以在 Python 中轻松完成这项工作。当你从 MySQLdb 中获取一个 datetime 列时,你会得到一个 Python datetime.datetime 对象。要转换其中之一,您可以使用 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())
于 2008-09-22T23:34:51.870 回答
1
我使用类似以下的方法从 MySQL 日期(本地时间)获取纪元(UTC)以来的秒数:
calendar.timegm(
time.gmtime(
time.mktime(
time.strptime(t,
"%Y-%m-%d %H:%M:%S"))))
此问题中的更多信息:如何在 Python 中将本地时间转换为 UTC?
于 2008-09-24T08:30:00.437 回答