我如何为下一个 6 点钟创建时间戳,无论是今天还是明天?
我尝试了使用 datetime.datetime.today() 并将日期替换为 +1 和小时 = 6,但我无法将其转换为时间戳。
需要您的帮助
若要生成明天上午 6 点的时间戳,可以使用如下所示的内容。这将创建一个表示当前时间的日期时间对象,检查当前小时是否<6 点钟,为下一个 6 点钟创建一个日期时间对象(包括在必要时添加递增的日期),最后将日期时间对象转换为时间戳
from datetime import datetime, timedelta
import time
# Get today's datetime
dtnow = datetime.now()
# Create datetime variable for 6 AM
dt6 = None
# If today's hour is < 6 AM
if dtnow.hour < 6:
# Create date object for today's year, month, day at 6 AM
dt6 = datetime(dtnow.year, dtnow.month, dtnow.day, 6, 0, 0, 0)
# If today is past 6 AM, increment date by 1 day
else:
# Get 1 day duration to add
day = timedelta(days=1)
# Generate tomorrow's datetime
tomorrow = dtnow + day
# Create new datetime object using tomorrow's year, month, day at 6 AM
dt6 = datetime(tomorrow.year, tomorrow.month, tomorrow.day, 6, 0, 0, 0)
# Create timestamp from datetime object
timestamp = time.mktime(dt6.timetuple())
print(timestamp)
要在处理正确遵守夏令时 (DST) 的时区时获取下一个 6 点钟,请执行以下操作:
from datetime import datetime, time, timedelta
import pytz # $ pip install pytz
from tzlocal import get_localzone # $ pip install tzlocal
DAY = timedelta(1)
local_timezone = get_localzone()
now = datetime.now(local_timezone)
naive_dt6 = datetime.combine(now, time(6))
while True:
try:
dt6 = local_timezone.localize(naive_dt6, is_dst=None)
except pytz.NonExistentTimeError: # no such time today
pass
except pytz.AmbiguousTimeError: # DST transition (or similar)
dst = local_timezone.localize(naive_dt6, is_dst=True)
std = local_timezone.localize(naive_dt6, is_dst=False)
if now < min(dst, std):
dt6 = min(dst, std)
break
elif now < max(dst, std):
dt6 = max(dst, std)
break
else:
if now < dt6:
break
naive_dt6 += DAY
一旦您有一个表示本地时区下一个 6 点钟的感知日期时间对象,就很容易获取时间戳:
timestamp = dt6.timestamp() # in Python 3.3+
或者在较旧的 Python 版本上:
timestamp = (dt6 - datetime(1970, 1, 1, tzinfo=pytz.utc)).total_seconds()
请参阅在 Python 中将 datetime.date 转换为 UTC 时间戳。
即使发生以下任何情况,该解决方案也有效:
- python(例如,
time.mktime()
调用)无法访问给定系统(特别是Windows)上的历史时区数据库 -pytz
提供对tz数据库的可移植访问 - 从现在到下一个
X
小时之间存在 DST 转换(在您的情况下X
是早上 6 点),或者如果本地时区的 UTC 偏移量因任何其他原因而更改 - "朴素日期时间对象 + 相对增量"解决方案将静默失败,无法找到正确的秒数,但时区感知日期时间对象可以找到正确的时差 - 标称的下一个
X
小时(今天或明天)在本地时区中不存在或不明确(大多数情况下,它发生在 DST 转换期间 - 每年在许多时区)。使用dateutil
tzinfos 或基于pytz
的解决方案(使用.localize()
而不使用is_dst=None
)的解决方案将以静默方式失败。在这种情况下,应用程序应显式处理NonExistentTimeError
和AmbiguousTimeError
异常 - 当前时间是在本地时区第一次发生不明确的
X
小时之后,但在第二次发生X
小时之前 - "rrule
+return min(localize(ndt, is_dst=True), localize(ndt, is_dst=False))
"解决方案将静默失败。上面AmbiguousTimeError
子句中的min
/max
代码可以正确处理它。