将timedelta转换为天、小时和分钟

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

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

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

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

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

559428 次浏览

timedelta有daysseconds属性。您可以自己轻松地转换它们。

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

至于DST,我认为最好的方法是将两个datetime对象都转换为秒。这样系统会为你计算夏令时。

>>> m13 = datetime(2010, 3, 13, 8, 0, 0)  # 2010 March 13 8:00 AM
>>> m14 = datetime(2010, 3, 14, 8, 0, 0)  # DST starts on this day, in my time zone
>>> mktime(m14.timetuple()) - mktime(m13.timetuple())     # difference in seconds
82800.0
>>> _/3600                                                # convert to hours
23.0

如果你有一个datetime.timedeltatdtd.days已经给出了你想要的“天数”。timedelta值将一天的分数保持为秒(而不是直接的小时或分钟),所以你确实必须执行“令人作呕的简单数学”,例如:

def days_hours_minutes(td):
return td.days, td.seconds//3600, (td.seconds//60)%60

我不明白

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

我使用了以下方法:

delta = timedelta()
totalMinute, second = divmod(delta.seconds, 60)
hour, minute = divmod(totalMinute, 60)
print(f"{hour}h{minute:02}m{second:02}s")

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

下面是一个小函数,我把它放在一起,精确到微秒:

def tdToDict(td:datetime.timedelta) -> dict:
def __t(t, n):
if t < n: return (t, 0)
v = t//n
return (t -  (v * n), v)
(s, h) = __t(td.seconds, 3600)
(s, m) = __t(s, 60)
(micS, milS) = __t(td.microseconds, 1000)


return {
'days': td.days
,'hours': h
,'minutes': m
,'seconds': s
,'milliseconds': milS
,'microseconds': micS
}

下面是一个返回tuple的版本:

# usage: (_d, _h, _m, _s, _mils, _mics) = tdTuple(td)
def tdTuple(td:datetime.timedelta) -> tuple:
def _t(t, n):
if t < n: return (t, 0)
v = t//n
return (t -  (v * n), v)
(s, h) = _t(td.seconds, 3600)
(s, m) = _t(s, 60)
(mics, mils) = _t(td.microseconds, 1000)
return (td.days, h, m, s, mics, mils)

对于所有前来寻找实现的人:

以上帖子与datetime相关。Timedelta,遗憾的是它没有小时和秒的属性。到目前为止还没有提到,有一个包,里面有这些。你可以在这里找到它:

示例—计算:

>>> import timedelta


>>> td = timedelta.Timedelta(days=2, hours=2)


# init from datetime.timedelta
>>> td = timedelta.Timedelta(datetime1 - datetime2)

—属性:

>>> td = timedelta.Timedelta(days=2, hours=2)
>>> td.total.seconds
180000
>>> td.total.minutes
3000
>>> td.total.hours
50
>>> td.total.days
2

我希望这能帮助到一些人……

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

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

虽然pandas.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)

如果使用熊猫(至少是版本>1.0), Timedelta类有一个components属性,返回一个命名元组,其中所有字段都很好地布局。

如。

import pandas as pd
delta = pd.Timestamp("today") - pd.Timestamp("2022-03-01")
print(delta.components)

如果你使用的是python datetime包,你也可以像下面这样编码:

import datetime
tap_in = datetime.datetime.strptime("04:12", "%H:%M")
tap_out = datetime.datetime.strptime("18:20", "%H:%M")
num_of_hour = (tap_out - tap_in).total_seconds()/3600
num_of_hour # 14.133333333333333
timedelta = pd.Timestamp("today") - pd.Timestamp("2022-01-01")
print(timedelta.components)
print(timedelta.components.days)
print(timedelta.components.seconds)

将返回如下内容:

Components(days=281, hours=2, minutes=24, seconds=3, milliseconds=72, microseconds=493, nanoseconds=0)
281
3