我有一组日期数据:
(u'x', datetime.datetime(2018, 1, 5, 4, 49, 30))
(u'y', datetime.datetime(2018, 1, 5, 9, 59, 10))
(u'x', datetime.datetime(2018, 1, 13, 10, 23, 17))
(u'y', datetime.datetime(2018, 1, 15, 17, 16, 34))
(u'x', datetime.datetime(2018, 1, 22, 11, 9, 55))
(u'y', datetime.datetime(2018, 1, 22, 14, 24, 59))
这是我减去日期的代码:
for x in range(len(y)):
if y[x][0] == 'x' and y[x+1][0] != 'y':
#subtract the date
print y[x+1][1] - y[x][1]
上面的代码打印在下面:
5:09:40
2 days, 6:53:17
3:15:04
我的问题是如何将它们全部添加并将其转换为总计小时数?感谢你的帮助。
答案 0 :(得分:1)
这是一种方式。
import datetime
lst = [(u'x', datetime.datetime(2018, 1, 5, 4, 49, 30)),
(u'y', datetime.datetime(2018, 1, 5, 9, 59, 10)),
(u'x', datetime.datetime(2018, 1, 13, 10, 23, 17)),
(u'y', datetime.datetime(2018, 1, 15, 17, 16, 34)),
(u'x', datetime.datetime(2018, 1, 22, 11, 9, 55)),
(u'y', datetime.datetime(2018, 1, 22, 14, 24, 59))]
res = sum((y[1]-x[1]).total_seconds()/(60**2) for x, y in zip(lst[::2], lst[1::2]))
# 63.30027777777778
<强>解释强>
timedelta.total_seconds()
转换为秒。sum
并使用生成器表达式。