![](/img/trans.png)
[英]Converting string time with milliseconds, in a python column, to timestamp
[英]Python3 Timestamp to unix time (with sometime milliseconds)
我正在尝试将时间戳转换为Unix时间。
时间戳看起来像这样:
2018-01-16T20:26:16.35
所以现在我使用以下代码:
timestamp = '2018-01-16T20:26:16.35'
ts = timestamp.replace("T", " ")
tsUnix = time.mktime(datetime.datetime.strptime(ts, "%Y-%m-%d %H:%M:%S.%f").timetuple())
有时从那里获取时间戳的api给我的时间没有毫秒 。
这将导致错误,“与格式不匹配”。 (Du,%f不在那儿)
我需要编写解决方法的脚本还是为此提供功能? 有没有更好的方法从原始时间码中删除“ T”?
这是使用try
和except
处理您的问题的一种方法:
import time
import datetime
def get_ts_unix(ts):
try:
tsUnix = time.mktime(
datetime.datetime.strptime(ts, "%Y-%m-%dT%H:%M:%S.%f").timetuple()
)
except ValueError:
tsUnix = time.mktime(
datetime.datetime.strptime(ts, "%Y-%m-%dT%H:%M:%S").timetuple()
)
return tsUnix
例:
timestamps = ['2018-01-16T20:26:16.35', '2018-01-16T20:26:16']
for ts in timestamps:
print("%-24s: %f" % (ts, get_ts_unix(ts)))
输出:
2018-01-16T20:26:16.35 : 1516152376.000000
2018-01-16T20:26:16 : 1516152376.000000
要跳过ts = timestamp.replace("T", " ")
,请在格式字符串中添加一个T
timestamp = '2018-01-16T20:26:16.35'
time.mktime(datetime.datetime.strptime(timestamp, "%Y-%m-%dT%H:%M:%S.%f").timetuple())
# returns 1516130776.0
要修复毫秒,您可以使用python-dateutil包
from dateutil import parser
raw_timestamp = '2018-01-16T20:26:16.35'
parsed_time = parser.parse(raw_timestamp)
timestamp = parsed_time.timestamp()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.