将时间增量转换为天、小时和分钟
- 2025-02-25 09:07:00
- admin 原创
- 20
问题描述:
我有一个 timedelta。我想要从中得到天数、小时数和分钟数 - 无论是作为元组还是字典...我并不担心。
这些年来,我肯定已经用十几种语言做过十几次这样的事情了,但是 Python 通常对所有问题都有一个简单的答案,所以在提出一些令人作呕的简单(但冗长)的数学问题之前,我想在这里问一下。
Fooz 先生提出了一个很好的观点。
我正在处理“列表”(有点像 ebay 列表),每个列表都有持续时间。我试图通过以下方式找到剩余时间when_added + duration - now
我说的对吗?这不考虑夏令时?如果不考虑,增加/减少一小时的最简单方法是什么?
解决方案 1:
如果您有一个datetime.timedelta
值td
,td.days
已经给出了您想要的“天数”。timedelta
值将天的分数保留为秒(而不是直接为小时或分钟),因此您确实必须执行“令人作呕的简单数学”,例如:
def days_hours_minutes(td):
return td.days, td.seconds//3600, (td.seconds//60)%60
解决方案 2:
这更紧凑一些,您可以在两行中看到小时、分钟和秒。
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
解决方案 3:
days, hours, minutes = td.days, td.seconds // 3600, td.seconds // 60 % 60
至于夏令时,我认为最好的办法是将两个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
解决方案 4:
对于所有前来并寻求实现的人:
上述帖子与 datetime.timedelta 相关,遗憾的是它没有小时和秒的属性。到目前为止,还没有提到有一个包有这些属性。你可以在这里找到它:
检查源代码:https://github.com/andrewp-as-is/timedelta.py
可通过 pip 获取:https://pypi.org/project/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
我希望这可以帮助别人......
解决方案 5:
我不明白
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
您可以获得一分钟的分钟和秒数作为浮点数。
解决方案 6:
我使用了以下内容:
delta = timedelta()
totalMinute, second = divmod(delta.seconds, 60)
hour, minute = divmod(totalMinute, 60)
print(f"{hour}h{minute:02}m{second:02}s")
解决方案 7:
下面是我编写的一个小函数,可以精确到微秒地完成此操作:
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)
解决方案 8:
虽然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)
解决方案 9:
而如果你使用 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
解决方案 10:
我发现最简单的方法是使用str(timedelta)
。它将返回格式如下的字符串3 days, 21:06:40.001000
,您可以使用简单的字符串操作或正则表达式来解析小时和分钟。
解决方案 11:
这是另一种可能的方法,虽然比前面提到的方法更冗长一些。对于这种情况,这可能不是最好的方法,但它可以方便地以未存储在对象中的特定单位(周、小时、分钟、毫秒)获取时间长度,而无需记住或计算转换因子。
from datetime import timedelta
one_hour = timedelta(hours=1)
one_minute = timedelta(minutes=1)
print(one_hour/one_minute) # Yields 60.0
我有一个 timedelta。我想要从中得到天数、小时数和分钟数 - 无论是作为元组还是字典...我并不担心。
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
解决方案 12:
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
解决方案 13:
如果使用pandas (至少版本 >1.0),该类Timedelta
有一个components
属性,它返回一个命名元组,其中所有字段都布局得很好。
例如
import pandas as pd
delta = pd.Timestamp("today") - pd.Timestamp("2022-03-01")
print(delta.components)
解决方案 14:
timedeltas 有一个days
和seconds
属性..您可以轻松地自行转换它们。