我正在使用python脚本计算开始日期和结束日期之间的持续时间,比如20140520160000
和20140520170000
,这样我就可以得到小时。
我对这段代码有问题:
if epgDuration >= 0.10 and epgDuration <= 0.30:
epgwidth = "250"
我试图比较0.10分钟和0.30分钟之间的时间范围时出错。
我得到的错误是:TypeError:无法将datetime.timedelta与float进行比较。
错误就在这条线上:
if epgDuration >= 0.10 and epgDuration <= 0.30:
结果如下:
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 2:30:00
14:44:55 T:1580 NOTICE: 3:00:00
14:44:55 T:1580 NOTICE: 1:00:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 1:00:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
14:44:55 T:1580 NOTICE: 0:30:00
下面是我用来持续时间的代码:
for row in programs:
program_startdate = str(row[2])
program_endDate = str(row[3])
try:
start_date = datetime.datetime.strptime(program_startdate, "%Y%m%d%H%M%S")
end_date = datetime.datetime.strptime(program_endDate, "%Y%m%d%H%M%S")
except TypeError:
start_date = datetime.datetime.fromtimestamp(time.mktime(time.strptime(program_startdate, "%Y%m%d%H%M%S")))
end_date = datetime.datetime.fromtimestamp(time.mktime(time.strptime(program_endDate, "%Y%m%d%H%M%S")))
#workout the duration times to get the program time
epgDuration = end_date - start_date
if epgDuration >= 0.10 and epgDuration <= 0.30:
epgwidth = "250"
elif epgDuration >= 1.00 and epgDuration <= 1.29:
epgwidth = "500"
print epgwidth
要从
timedetla
对象获取分钟数,可以使用total_seconds()
并除以60:还请注意,您可以使用python的coolcomparison-chaining(例如
a <= b <= c
)实际上,不能将
timedelta
与浮点值进行比较。您可以将对象转换为秒:
其中10分钟是600秒,30分钟是1800秒。
或者创建新的
timedelta()
对象以进行比较:对于时差不在10-30分钟或1-1.5小时范围内的情况,我在
epgwidth
语句之前给了if
一个默认值。相关问题 更多 >
编程相关推荐