python - 对于 1970-01-01 之前的日期,Windows 上 datetime timestamp() 的解决方法
问题描述
我目前正在尝试通过将日期转换为时间戳来在数据集中生成数字特征。如果在 Mac 上运行,它可以完美运行,在 Windows 上它会抛出:
OS Error: [Errno 22] Invalid argument
这可能是由于 Windows不支持 1970-01-01 之前的 unix 时间戳。我的日期从 1955 年开始。这是我的代码:
import time
import datetime
current_timestamp = time.time()
df.loc[:, "FEATURE_num"] = df["FEATURE"].apply(lambda d: datetime.datetime.strptime(d, '%Y-%m-%d').timestamp() if isinstance(d, str) else current_timestamp)
我在某处看到有人建议使用datetime.timedelta()
,但我不知道如何集成它。
解决方案
您可以通过(隐式)使用datetime.timedelta
来计算“公历”时间戳,该时间戳对于从 1582 年 10 月 15 日到现在(或您想使用的其他“纪元”)的日期有效。
正如函数的文档字符串所示,默认情况下,日期字符串将使用'%Y-%m-%d'
strptime
-like格式字符串参数进行解析,但可以覆盖。
from datetime import datetime
GREGORIAN_EPOCH = datetime.strptime('1582-10-15', '%Y-%m-%d')
def gregorian_timestamp(date, format='%Y-%m-%d'):
""" Calculate timestamp using start of Gregorian calender as epoch.
The date parameter can be either a string or a datetime.datetime
object. Strings will be parsed using the '%Y-%m-%d' format by default
unless a different one is specfied via the optional format parameter.
"""
try:
date = datetime.strptime(date, format)
except TypeError:
pass
return (date - GREGORIAN_EPOCH).total_seconds() # The timedelta in seconds.
if __name__ == '__main__':
current_date = datetime.now()
timestamp = gregorian_timestamp(current_date)
print('gregorian timestamp:', timestamp) # -> gregorian timestamp: 13768250461.136208
timestamp = gregorian_timestamp('1970-01-01')
print('gregorian timestamp:', timestamp) # -> gregorian timestamp: 12219292800.0
timestamp = gregorian_timestamp('1955-02-28')
print('gregorian timestamp:', timestamp) # -> gregorian timestamp: 11750918400.0
timestamp = gregorian_timestamp('1582-10-15')
print('gregorian timestamp:', timestamp) # -> gregorian timestamp: 0.0
推荐阅读
- python - 除了(python,爬虫)的可能性
- java - Spring(自动装配)组件在同一个类中使用多个
- c# - Visual Studio 2017 仅具有适用于 .NET Core 2.x 的脱机 Nuget 包。如何获得在线包裹?
- php - 如何将数组数组映射到单个关联数组?
- arrays - 如何将两个数组交叉合并为一个?
- android - 添加视图后执行视图动画
- node.js - 角 6 | Express : 在 dist 文件上出现 404 错误
- swift - 如何在此函数中添加另一个条件
- django - 在 generics.RetrieveDestroyAPIView 中检查模型中的字段
- php - 在类方法中包含 wp-load.php 会导致致命错误