python中将datetime对象转化为时间戳


从mongodb中读取出来的记录中,时间存储在datetime对象里,返回给客户端的却要求是时间戳格式,因此需要将对应的datetime时间转化为时间戳,从stackoverflow上找到同样的问题和详尽的答案:

https://stackoverflow.com/questions/8777753/converting-datetime-date-to-utc-timestamp-in-python

如下以2012年12月12日12分12秒为例,求其时间戳

1,如果是Python3.3及以上版本:

可以直接调用新函数: datetime.timestamp:

>>> dt = datetime.datetime(2012, 12, 12, 12, 12, 12)
>>> dt.replace(tzinfo=datetime.timezone.utc).timestamp()
1355314332.0

第一种方法必须指定tzinfo为utc时区,否则计算时会将当前时区(中国为UTC+8)和UTC的时间差换算后计算时间戳,导致得出的timestamp比UTC要快或者慢 n*3600秒(比如为中国时区则会慢8*3600s)  

2,如果是Python3

>>> ep = datetime.datetime(1970, 1, 1)
>>> dt = datetime.datetime(2012, 12, 12, 12, 12, 12)
>>> (dt - ep)/datetime.timedelta(seconds=1)
1355314332.0

3,如果是Python2:

>>> ep = datetime.datetime(1970, 1, 1)
>>> dt = datetime.datetime(2012, 12, 12, 12, 12, 12)
>>> (dt - ep).total_seconds()
1355314332.0

 第2、3种方法的原理,其实就是直接拿记录时间的datetime对象,减去代表1970年1月1日0时0分0秒(此时刻时间戳为0)的datetime,得到一个timedelta,再将其换算成秒数即为时间戳,只要保证ep和dt位于一个时区,计算结果就会相同,因而不需要特别指定utc时区。