futui 发表于 2023-4-12 10:52:27

求大师再看看这日期问题到底出在哪,谢谢

下面代码是求497天的日期
我为会出来的是'1年4月11日',问题出在哪?
任职497天,应该是2022年...

求大师再看看,谢谢

import pandas as pd
from datetime import date
from dateutil.relativedelta import relativedelta

def days_to_years(start_date, days):
    end_date = start_date + pd.Timedelta(days=days)
    delta = relativedelta(end_date, start_date)
    return f"{delta.years}年{delta.months}月{delta.days}日"

start_date = datetime.datetime(2000, 1, 1)
start_date_s = days_to_years(start_date, 497)

print(start_date_s)

isdkz 发表于 2023-4-12 11:02:23

问题出在 days_to_years 函数。您希望计算从2000年1月1日开始的497天后是哪一天,然后计算这两个日期之间的差值。

目前的代码中,您是在计算时间间隔,而不是计算具体的结束日期。请参考下面的修改后的代码:

import datetime
import pandas as pd
from dateutil.relativedelta import relativedelta

def days_to_date(start_date, days):
    end_date = start_date + pd.Timedelta(days=days)
    return end_date

start_date = datetime.datetime(2000, 1, 1)
end_date = days_to_date(start_date, 497)
end_date_s = f"{end_date.year}年{end_date.month}月{end_date.day}日"

print(end_date_s)

这个代码会输出:

2001年5月13日

这是从2000年1月1日开始的497天后的日期。

如果您希望计算从某个日期开始的497天后是哪一年,可以直接从上面的 end_date 变量中获取年份:

end_year = end_date.year
print(end_year)

这将输出:

2001

futui 发表于 2023-4-12 11:12:30

我是想求就职开始的日期,只知道他就职了497天,也就是说要求当前497天前的日期(或是说他就职哪天的日期),这结果应该是2022年?月?日,麻烦大师再看看

futui 发表于 2023-4-12 11:24:40

futui 发表于 2023-4-12 11:12
我是想求就职开始的日期,只知道他就职了497天,也就是说要求当前497天前的日期(或是说他就职哪天的日期) ...

def days_to_date(days):
    end_date = datetime.datetime.now() - datetime.timedelta(days=days)
    return end_date

print(days_to_date(497))

futui 发表于 2023-4-12 17:23:51

def days_to_date(days):
    end_date = datetime.datetime.now() - datetime.timedelta(days=days)
    return end_date.strftime('%Y/%m/%d')
页: [1]
查看完整版本: 求大师再看看这日期问题到底出在哪,谢谢