我有一个time。我想要其中的日,小时和分钟-作为元组或字典…我并不大惊小怪。

这些年来,我肯定用十几种语言做过十几次,但Python通常对所有问题都有一个简单的答案,所以我想在抛出一些令人作呕的简单(但冗长)数学之前,在这里问一下。

富兹先生提出了一个很好的观点。

我处理的是“列表”(有点像ebay列表),其中每个列表都有一个持续时间。我试图通过做when_added + duration - now找到剩下的时间

我说的对吗,这不包括夏令时?如果不是,最简单的增加/减少一个小时的方法是什么?


当前回答

timedelta有一个天和秒属性。您可以自己轻松地转换它们。

其他回答

我不明白

days, hours, minutes = td.days, td.seconds // 3600, td.seconds // 60 % 60

这个怎么样

days, hours, minutes = td.days, td.seconds // 3600, td.seconds % 3600 / 60.0

每分钟的分和秒都是浮点数。

这个更紧凑一些,小时、分和秒分在两行。

days = td.days
hours, remainder = divmod(td.seconds, 3600)
minutes, seconds = divmod(remainder, 60)
# If you want to take into account fractions of a second
seconds += td.microseconds / 1e6

我发现最简单的方法是使用str(timedelta)。它将返回格式为3天,21:06:40.001000的sting,您可以使用简单的字符串操作或正则表达式解析小时和分钟。

而熊猫。Timedelta并没有直接提供这些属性,它确实提供了一个叫做total_seconds的方法,基于它可以很容易地推导出日、小时和分钟:

import pandas as pd
td = pd.Timedelta("2 days 12:30:00")
minutes = td.total_seconds()/60
hours = minutes/60
days = hours/ 24
print(minutes, hours, days)

这是另一种可能的方法,尽管比前面提到的要冗长一些。对于这种情况,这可能不是最好的方法,但能够以对象中不存储的特定单位(周、小时、分钟、毫秒)获得时间持续时间是很方便的,而且不需要记住或计算转换因子。

from datetime import timedelta
one_hour = timedelta(hours=1)
one_minute = timedelta(minutes=1)
print(one_hour/one_minute)  # Yields 60.0

我有一个time。我想要其中的日,小时和分钟-作为元组或字典…我并不大惊小怪。

in_time_delta = timedelta(days=2, hours=18, minutes=30)
td_d = timedelta(days=1)
td_h = timedelta(hours=1)
td_m = timedelta(minutes=1)
dmh_list = [in_time_delta.days,
            (in_time_delta%td_d)//td_h,
            (in_time_delta%td_h)//td_m]

应该将[2,18,30]分配给dmh_list