将字符串列表转换为日期时间

时间:2019-01-27 01:46:49

标签: python datetime python-datetime timedelta

我正在尝试将字符串列表转换为日期时间。

以下是我正在处理的数据的示例:
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

任何帮助或指导都将不胜感激!

5 个答案:

答案 0 :(得分:2)

datetime.datetime对象必须采用一定范围内的参数,即分钟数必须在059之间。但是,您可以创建一个类来处理此所需的行为。该类可以将输入转换为所需的时间戳格式,存储原始字符串,并提供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

现在在循环中,您可以做任何您想做的事。