我的情况是我有一个带时间戳的项目列表,但实际的时间都被挤在一起了。像这样:
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)
回报:
['你好世界']
如果可能的话,我希望它不是一个函数,我想要一种内联的方法。它应该尽可能高效。我总是可以从我找到的函数中提取列表理解,但我觉得它效率不高,而且看起来不太对劲。
答案可能很简单,我只是不知道。再次感谢。