我正在尝试将字符串列表转换为日期时间。
以下是我正在处理的数据的示例:
x = ['59:55:00', '59:55:00', '59:58:00', '1:00:02', '1:00:05', '1:01:26']
例如,该列表应该反映59分钟,58秒到1小时,0分钟和5秒。
我知道这是一种古怪的格式,但是我在玩我已经处理过的牌。进入大于59分钟的值后,我不确定如何处理数据。
我尝试使用:
from datetime import datetime
for i in x:
datetime_object = datetime.strptime(i, '%M:%S:%f')
print(datetime_object)
我的结果是:
1900-01-01 00:59:55
1900-01-01 00:59:55
1900-01-01 00:59:58
1900-01-01 00:01:00.020000
1900-01-01 00:01:00.050000
1900-01-01 00:01:01.260000
我想将输出保持在几分钟和几秒钟的时间内。
例如,1:01:26
将是00:61:26
所以我想要的输出看起来像:
1900-01-01 00:59:55
1900-01-01 00:59:55
1900-01-01 00:59:58
1900-01-01 00:60:02
1900-01-01 00:60:02
1900-01-01 00:61:26
任何帮助或指导都将不胜感激!
答案 0 :(得分:2)
datetime.datetime
对象必须采用一定范围内的参数,即分钟数必须在0
和59
之间。但是,您可以创建一个类来处理此所需的行为。该类可以将输入转换为所需的时间戳格式,存储原始字符串,并提供to_date
属性以将实际时间戳作为datetime.datetime
对象进行检索:
import datetime
class Minutes:
d = datetime.datetime.now()
def __init__(self, _str, _year = None):
self._val = _str
d = datetime.datetime.now()
self.year = _year if _year is not None else '-'.join(str(getattr(d, i)) for i in ['year', 'month', 'day'])
@property
def to_date(self):
return datetime.datetime(*map(int, self.year.split('-')), *map(int, str(self).split(':')))
def __str__(self):
_h, _m, _s = map(int, self._val.split(':'))
h, m, s = 0 if _h else _h, _m+(_h*60) if _h else _m, _s
return f'{self.year} '+':'.join(str(i).zfill(2) for i in [h, m, s])
def __repr__(self):
return str(self)
x = ['59:55:00', '59:55:00', '59:58:00', '1:00:02', '1:00:05', '1:01:26']
new_x = [Minutes(i, '1900-01-01') for i in x]
输出:
[1900-01-01 00:3595:00,
1900-01-01 00:3595:00,
1900-01-01 00:3598:00,
1900-01-01 00:60:02,
1900-01-01 00:60:05,
1900-01-01 00:61:26]
答案 1 :(得分:1)
也许strptime
不是这里的正确工具(为简便起见,省略了一些错误检查):
def convert(s):
parts = [int(i) for i in s.split(":")]
if parts[0] < 3: # 3 is arbitrary value, may need adaption
# Assuming format hour:min:sec
h, m, s = parts
millis = 0
else:
# Assuming format min:sec:millisec
m, s, millis = parts
h = 0
return "1900-01-01 00:{:02}:{:02}".format(h * 60 + m, s)
x = ['59:55:00', '59:55:00', '59:58:00', '1:00:02', '1:00:05', '1:01:26']
print(*(convert(i) for i in x), sep="\n")
输出:
1900-01-01 00:59:55
1900-01-01 00:59:55
1900-01-01 00:59:58
1900-01-01 00:60:02
1900-01-01 00:60:05
1900-01-01 00:61:26
答案 2 :(得分:1)
您的列表包含持续时间,而不是时间。 datetime.timedelta
是为此目的而设计的,但是如果您想要一种非常特定的字符串格式来输出,则不是不必要。
输入数据的问题是格式不一致。如果您愿意为第一部分硬编码一个极限值,则可以通过三元语句应用切换:
from datetime import timedelta
x = ['59:55:00', '59:55:00', '59:58:00', '1:00:02', '1:00:05', '1:01:26']
def converter(value, limit=59):
var1, var2, var3 = map(int, value.split(':'))
switch = var1 < limit
mins = var1 * 60 + var2 if switch else var1
secs = var3 if switch else var2
return f'00:{mins:02}:{secs:02}'
res = list(map(converter, x))
print(res)
# ['00:59:55', '00:59:55', '00:59:58', '00:60:02', '00:60:05', '00:61:26']
答案 3 :(得分:0)
>>> time = datetime.datetime.now()
>>> halfformatted = time.strftime('00:{minutes}:%S.%f')
>>> minutes_total = time.hour * 60 + time.minute
>>> halfformatted.format(minutes=minutes_total)
'00:358:33.339341'
答案 4 :(得分:0)
鉴于可以保证数据不会回到以前的格式,我们可以对其进行规范化。为了保持环境整洁,最好将其包装在生成器中,以免使您的主要应用程序逻辑混乱。例如:
def normalized(times):
hms = False
last_minute = 0
for t in x:
h, m, s = [int(i) for i in t.split(':')]
if not hms:
if h < last_minute:
hms = True
else:
h, m, s = 0, h, m
last_minute = m
yield f'{h:02}:{m:02}:{s:02}'
x = ['59:55:00', '59:55:00', '59:58:00', '1:00:02', '1:00:05', '1:01:26']
for v in normalized(x):
print(v)
产生
00:59:55
00:59:55
00:59:58
01:00:02
01:00:05
01:01:26
现在在循环中,您可以做任何您想做的事。