在Python中将年/月/日转换为年份

我正在使用Python的“date时间”模块,即:

>>> import datetime >>> today = datetime.datetime.now() >>> print today 2009-03-06 13:24:58.857946 

我想计算闰年敏感的年份。 oday(2009年3月6日)是2009年的第65天。 这里是基于networking的DateTime计算器 。

无论如何,我看到了两个select:

  1. 创build一个number_of_days_in_month数组= [31,28,…],决定是否是闰年,手动总结天数

  2. 使用datetime.timedelta进行猜测,然后进行二进制search以查找一年中正确的一天:

 >>> import datetime >>> YEAR = 2009 >>> DAY_OF_YEAR = 62 >>> d = datetime.date(YEAR, 1, 1) + datetime.timedelta(DAY_OF_YEAR - 1) 

这些都感觉非常笨重,我有一种直觉,认为有更多的“Pythonic”计算日常的方式。 任何想法/build议?

有一个非常简单的解决scheme:

 day_of_year = datetime.now().timetuple().tm_yday 

你不能使用strftime吗?

 >>> import datetime >>> today = datetime.datetime.now() >>> print today 2009-03-06 15:37:02.484000 >>> today.strftime('%j') '065' 

编辑

正如在注释中指出的,如果你想用这个数字进行比较或计算,你将不得不把它转换成int()因为strftime()返回一个string。 如果是这样,你最好使用DzinX的答案。

DZinX的回答是一个很好的答案。 我find这个问题,同时寻找反函数。 我发现这个工作:

 import datetime datetime.datetime.strptime('1936-077T13:14:15','%Y-%jT%H:%M:%S') >>>> datetime.datetime(1936, 3, 17, 13, 14, 15) datetime.datetime.strptime('1936-077T13:14:15','%Y-%jT%H:%M:%S').timetuple().tm_yday >>>> 77 

我对这里的礼仪不是很确定,但是我认为一个指向反函数的指针可能对像我这样的人有用。

我想在Python 3.4,Linux x64上介绍不同方法的性能。 从线轮廓仪摘录:

  Line # Hits Time Per Hit % Time Line Contents ============================================================== (...) 823 1508 11334 7.5 41.6 yday = int(period_end.strftime('%j')) 824 1508 2492 1.7 9.1 yday = period_end.toordinal() - date(period_end.year, 1, 1).toordinal() + 1 825 1508 1852 1.2 6.8 yday = (period_end - date(period_end.year, 1, 1)).days + 1 826 1508 5078 3.4 18.6 yday = period_end.timetuple().tm_yday (...) 

所以最有效的是

 yday = (period_end - date(period_end.year, 1, 1)).days 

只需从date减去1月1日:

 import datetime today = datetime.datetime.now() day_of_year = (today - datetime.datetime(today.year, 1, 1)).days + 1 

如果你有理由避免使用datetime模块,那么这些函数将起作用。

 def is_leap_year(year): """ if year is a leap year return True else return False """ if year % 100 == 0: return year % 400 == 0 return year % 4 == 0 def doy(Y,M,D): """ given year, month, day return day of year Astronomical Algorithms, Jean Meeus, 2d ed, 1998, chap 7 """ if is_leap_year(Y): K = 1 else: K = 2 N = int((275 * M) / 9.0) - K * int((M + 9) / 12.0) + D - 30 return N def ymd(Y,N): """ given year = Y and day of year = N, return year, month, day Astronomical Algorithms, Jean Meeus, 2d ed, 1998, chap 7 """ if is_leap_year(Y): K = 1 else: K = 2 M = int((9 * (K + N)) / 275.0 + 0.98) if N < 32: M = 1 D = N - int((275 * M) / 9.0) + K * int((M + 9) / 12.0) + 30 return Y, M, D