python字符串格式时间转化为时间戳

1、问题:

在服务请求记录时间时,往往是毫秒级的,在秒上计数会有小数点,例如

dt= '2020-09-09 15:03:56.742'

 time.strptime支持的几种数字类型如下;

decimal鄙人觉得应该支持浮点数;尝试format_string="%Y-%m-%d %H:%M:%S" 直接解析,无奈报错了;时间转化代码如下

import time
#将时间字符串转换为10位时间戳,时间字符串默认为2017-10-01 13:37:04格式
def date_to_timestamp(date, format_string="%Y-%m-%d %H:%M:%S"):
    time_array = time.strptime(date, format_string)
    time_stamp = int(time.mktime(time_array))
    return time_stamp

2、报错:

使用上面的一段代码进行转化时,报如下错误

ValueError: unconverted data remains: .742

 

3、解决:

最主要的的原因是小数点后面的位数无法解析了,将

format_string="%Y-%m-%d %H:%M:%S" 变为如下格式

format_string="%Y-%m-%d %H:%M:%S.%f"

即可解决

import time
#将时间字符串转换为10位时间戳,时间字符串默认为2017-10-01 13:37:04格式
def date_to_timestamp(date, format_string="%Y-%m-%d %H:%M:%S.%f"):
    time_array = time.strptime(date, format_string)
    time_stamp = int(time.mktime(time_array))
    return time_stamp

 

参考

https://blog.csdn.net/mighty13/article/details/78147357 (非毫秒级时间转化)

https://blog.csdn.net/woddle/article/details/97389197?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param (13位的时间转化)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值