如果给定时间来源,如何将日期时间从十进制转换为“%y%m%d%H:%m:%S”?

2024-06-17 16:25:46 发布

您现在位置:Python中文网/ 问答频道 /正文

我四处寻找,但找不到一个能解决我问题的答案。你知道吗

我使用的是python3.7,我需要将一系列十进制数转换成%Y-%m-%d %H:%M:%S形式的datetime对象。在这样做时,我需要考虑一个原点,例如:

t = 0.000000等于2016-06-25 00:00:00

t = 0.010417等于?你知道吗

等等。我知道在我的十进制时间里,整数部分是天,小数部分是天的分数。你知道吗

我用Rhere找到了答案。我还认为我可能需要使用类方法date.fromordinal(ordinal)或类似的方法,但我不知道怎么做。你知道吗

这就是我迄今为止所尝试的:

例如t = 1.010416

import datetime as DT
from datetime import timedelta  
day = int(x)
datetime_object = DT.datetime.strptime("2016-06-25 00:00:00", '%Y-%m-%d %H:%M:%S')
python_datetime = DT.datetime.fromordinal(day) + timedelta(days=datetime_object.day-1)

我得到:

datetime.datetime(1, 1, 25, 0, 0)

但我不能加上2016年和月份。另外,对于int(t) = 0的每种情况,我得到:

ValueError: ordinal must be >= 1

非常感谢你的回答


Tags: 对象方法答案importdatetimeobject时间dt
2条回答

考虑到我对其他答案的评论,这里只留下一个明确的答案:

from datetime import datetime,timedelta

base_date = datetime(2016, 6, 25)
deltas = (2.34857, 0.010417, 1.010416)

for delta in deltas:
    print((base_date + timedelta(delta)).strftime('%Y-%m-%d %H:%M:%S'))

该代码产生以下输出:

>>> from datetime import datetime,timedelta
>>> 
>>> base_date = datetime(2016, 6, 25)
>>> deltas = (2.34857, 0.010417, 1.010416)
>>> 
>>> for delta in deltas:
...     print((base_date + timedelta(delta)).strftime('%Y-%m-%d %H:%M:%S'))
... 
2016-06-27 08:21:56
2016-06-25 00:15:00
2016-06-26 00:14:59
>>> 

timedelta将其数据存储为以下格式:(DAYS, SECONDS),因此您可以轻松地计算它:

import datetime

t = 2.34857

# Full days
days = int(t)

# Part of a day
part_of_day = t - int(t)
seconds = int(part_of_day * 24 * 60 * 60)

# Calculate the time delta
dt = datetime.timedelta(
    days=days,
    seconds=seconds
)

# Add t-delta to the first day
first_day = datetime.datetime(2016, 6, 25)
current_time = first_day + dt
current_time

将返回:

datetime.datetime(2016, 6, 27, 8, 21, 56)

然后可以使用以下函数将其转换为字符串:

datetime.datetime.strftime(current_time, '%Y-%m-%d %H:%M:%S')

'2016-06-27 08:21:56'


编辑1:不必按天秒构建时间增量,只需使用float days作为参数(多亏了accdias!)地址:

dt = datetime.timedelta(days=t)

相关问题 更多 >