假设您有这种格式的时间:
a = [..., 800.0, 830.0, 900.0, 930.0, 1000.0, 1030.0, ...]
问题是缺少数小时的前导零.例如00:30由30表示,08:00由800表示,00:00由2400表示.
是否可以使用strptime方法将此数据解析为时间对象?
我尝试使用以下代码
hours = [time.strptime(str(int(i)), "%H%M") for i in a]
但得到了
ValueError: unconverted data remains: 0
附:我正在使用Python 2.7.
解决方法:
使用zfill根据需要添加这些零:
hours = [time.strptime(i[:-1].zfill(4), "%H%M") for i in a]
通过使用i [: – 1]我们删除那个讨厌的尾随点,而.zfill(4)将在左边添加足够的0个字符使其成为4位数.
演示:
>>> import time
>>> a = ['800.', '830.', '900.', '30.']
>>> [time.strptime(i[:-1].zfill(4), "%H%M") for i in a]
[time.struct_time(tm_year=1900, tm_mon=1, tm_mday=1, tm_hour=8, tm_min=0, tm_sec=0, tm_wday=0, tm_yday=1, tm_isdst=-1), time.struct_time(tm_year=1900, tm_mon=1, tm_mday=1, tm_hour=8, tm_min=30, tm_sec=0, tm_wday=0, tm_yday=1, tm_isdst=-1), time.struct_time(tm_year=1900, tm_mon=1, tm_mday=1, tm_hour=9, tm_min=0, tm_sec=0, tm_wday=0, tm_yday=1, tm_isdst=-1), time.struct_time(tm_year=1900, tm_mon=1, tm_mday=1, tm_hour=0, tm_min=30, tm_sec=0, tm_wday=0, tm_yday=1, tm_isdst=-1)]
如果它们是浮点值,请使用它们上的format()
function为您提供零填充值:
>>> format(800., '04.0f')
'0800'
这样做:
hours = [time.strptime(format(i % 2400, '04.0f'), "%H%M") for i in a]
其中%2400将您的值标准化为0.到2399.范围.