求大师再看看这日期问题到底出在哪,谢谢
下面代码是求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)
问题出在 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 我是想求就职开始的日期,只知道他就职了497天,也就是说要求当前497天前的日期(或是说他就职哪天的日期),这结果应该是2022年?月?日,麻烦大师再看看 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)) def days_to_date(days):
end_date = datetime.datetime.now() - datetime.timedelta(days=days)
return end_date.strftime('%Y/%m/%d')
页:
[1]