1

我的情况是我有一个带时间戳的项目列表,但实际的时间都被挤在一起了。像这样:

time = "165420" # 16:54:20 (or, 4:54 PM and 20 seconds.)

我想要一个脚本来遍历这些行并能够将时间戳转换为日期时间。我有年月日已经没问题了。但就当时的情况而言,我迫切希望找到一个优雅而简单的解决方案。我决定首先暴力破解它以继续我的代码,并最终得到:

import datetime

dt_timestamp = extract_dt("2012-11-09-165420") # example

def extract_dt(timestamp):
    ds = timestamp.split('-') #split into groups (0,1,2 are the date, 3 is the time.
    d = [int(i) for i in ds[:3]] + [int(ds[3][0:2]), int(ds[3][2:4]), int(ds[3][4:6])]
    return datetime.datetime(*d)

在尝试解决我的情况时,我看到这个问题有很多变化,有很多答案。

我找到了这个解决方案

def nsplit(s, n):
    return [s[k:k+n] for k in xrange(0, len(s), n)]

这对我很有效:

>>> s = "165420"
>>> n = 2
>>> [s[k:k+n] for k in xrange(0, len(s), n)]
['16', '54', '20']

但我很确定必须有一种更好、更优雅的方式将字符串分成大小相等的组,正如我提供的链接中提到的那样(但由于链接海报有错字而已修复):

TheFunction("Hello World",3)

回报:

['你好世界']

如果可能的话,我希望它不是一个函数,我想要一种内联的方法。它应该尽可能高效。我总是可以从我找到的函数中提取列表理解,但我觉得它效率不高,而且看起来不太对劲。

答案可能很简单,我只是不知道。再次感谢。

4

2 回答 2

2

我不知道比您在问题中提到的更优雅的分块字符串解决方案,但datetime.datetime.strptime()可以解决您的实际问题:

>>> from datetime import datetime
>>> datetime.strptime("2012-11-09-165420", "%Y-%m-%d-%H%M%S")
datetime.datetime(2012, 11, 9, 16, 54, 20)
于 2012-11-11T15:09:54.563 回答
2

你可以用textwrap.wrap()这个:

>>> import textwrap
>>> s = "165420"
>>> n = 2
>>> textwrap.wrap(s, n)
['16', '54', '20']
于 2014-01-12T19:07:45.117 回答