Dateutil的timedelta
对象似乎有自定义__str__
方法:
In [1]: from datetime import timedelta
In [2]: td = timedelta(hours=2)
In [3]: str(td)
Out[3]: '2:00:00'
我想要做的是从字符串表示中重新创建一个timedelta
对象。但是,据我所知,datetime.parser.parse
方法将始终返回datetime.datetime
个对象(参见https://dateutil.readthedocs.io/en/stable/parser.html):
In [4]: import dateutil.parser
In [5]: dateutil.parser.parse(str(td))
Out[5]: datetime.datetime(2016, 11, 25, 2, 0)
我现在看到这样做的唯一方法是,用Convert a timedelta to days, hours and minutes的说法,“破坏一些令人作呕的简单(但冗长的)数学”,以获得秒,分,小时等,以及将这些传递回新__init__
的{{1}}。或者是否有更简单的方法?
答案 0 :(得分:3)
受pytimeparse启发的模块How to construct a timedelta object from a simple string似乎通过返回秒数来完成繁重的任务。我只是在它周围放了一个包装器,它返回一个具有相同秒数的timedelta
对象:
#!/usr/bin/env python3.5
import datetime
import pytimeparse
import unittest
def reconstruct_timedelta(td_string):
seconds = pytimeparse.parse(td_string)
return datetime.timedelta(seconds=seconds)
class TestReconstruction(unittest.TestCase):
def test_reconstruct_timedelta_is_inverse_of_str(self):
td = datetime.timedelta(weeks=300, days=20, hours=3, minutes=4, milliseconds=254, microseconds=984)
td_reconstructed = reconstruct_timedelta(str(td))
self.assertTrue(td == td_reconstructed)
if __name__ == "__main__":
unittest.main()
从测试中可以看出,重建的timedelta
对象与原始对象相同,即使用milliseconds
和microseconds
初始化任意数字也是如此。 / p>
答案 1 :(得分:3)
使用datetime.strptime
将字符串转换为timedelta。
import datetime
td = datetime.timedelta(hours=2)
# timedelta to string
s = str(td) # 2:00:00
# string to timedelta
t = datetime.datetime.strptime(s,"%H:%M:%S")
td2 = datetime.timedelta(hours=t.hour, minutes=t.minute, seconds=t.second)
答案 2 :(得分:0)
怎么用泡菜?你可以参考https://docs.python.org/2/library/pickle.html 序列化时间增量对象,稍后再返回该对象。
import pickle
tdi = pickle.dumps(td)
tdo = pickle.loads(tdi) # will have the time delta object
str(tdo)