我必须在未来5分钟内创建一个“Expires”值,但是我必须以UNIX时间戳格式提供它。到目前为止我有这个,但它看起来像个黑客。

def expires():
    '''return a UNIX style timestamp representing 5 minutes from now'''
    epoch = datetime.datetime(1970, 1, 1)
    seconds_in_a_day = 60 * 60 * 24
    five_minutes = datetime.timedelta(seconds=5*60)
    five_minutes_from_now = datetime.datetime.now() + five_minutes
    since_epoch = five_minutes_from_now - epoch
    return since_epoch.days * seconds_in_a_day + since_epoch.seconds

是否有一个模块或函数为我进行时间戳转换?


当前回答

另一种方法是使用calendar.timegm:

future = datetime.datetime.utcnow() + datetime.timedelta(minutes=5)
return calendar.timegm(future.timetuple())

它也比%s标志更易于移植到strftime(在Windows上不工作)。

其他回答

另一种方法是使用calendar.timegm:

future = datetime.datetime.utcnow() + datetime.timedelta(minutes=5)
return calendar.timegm(future.timetuple())

它也比%s标志更易于移植到strftime(在Windows上不工作)。

你可以使用datetime。strftime获取Epoch格式的时间,使用%s格式字符串:

def expires():
    future = datetime.datetime.now() + datetime.timedelta(seconds=5*60)
    return int(future.strftime("%s"))

注意: 这只适用于linux,并且该方法不适用于时区。

现在,在Python >= 3.3中,您可以调用timestamp()方法来获取作为浮点数的时间戳。

import datetime
current_time = datetime.datetime.now(datetime.timezone.utc)
unix_timestamp = current_time.timestamp() # works if Python >= 3.3

unix_timestamp_plus_5_min = unix_timestamp + (5 * 60)  # 5 min * 60 seconds

下面是一个较少破坏的基于datetime的解决方案,从datetime对象转换为posix时间戳:

future = datetime.datetime.utcnow() + datetime.timedelta(minutes=5)
return (future - datetime.datetime(1970, 1, 1)).total_seconds()

查看更多详细信息,在转换日期时间。在Python中,date转换为UTC时间戳。

关键是在开始转换之前,要确保使用的所有日期都位于utc时区。参见http://pytz.sourceforge.net/了解如何正确地做到这一点。通过规范化为utc,可以消除夏令时转换的模糊性。然后,您可以安全地使用timedelta来计算到unix epoch的距离,然后转换为秒或毫秒。

注意,生成的unix时间戳本身位于UTC时区。如果希望看到本地化时区中的时间戳,则需要进行另一次转换。

还要注意,这只适用于1970年之后的日期。

   import datetime
   import pytz

   UNIX_EPOCH = datetime.datetime(1970, 1, 1, 0, 0, tzinfo = pytz.utc)
   def EPOCH(utc_datetime):
      delta = utc_datetime - UNIX_EPOCH
      seconds = delta.total_seconds()
      ms = seconds * 1000
      return ms