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

时间:2009-03-06 20:34:32

标签: python datetime

我正在使用Python“datetime”模块,即:

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

我想计算一年中对闰年敏感的日期。例如今天(2009年3月6日)是2009年的第65天。Here's web-based DateTime calculator

无论如何,我看到两个选项:

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

  2. 使用datetime.timedelta进行猜测&然后二元搜索一年中的正确日期:

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

    这些都感觉非常笨重&我有一种直觉,就是有更多的“Pythonic”方式来计算一年中的某一天。有什么想法/建议吗?

7 个答案:

答案 0 :(得分:214)

有一个非常简单的解决方案:

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

答案 1 :(得分:33)

你不能使用strftime吗?

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

修改

如评论中所述,如果您希望使用此数字进行比较或计算,则必须将其转换为int(),因为strftime()会返回一个字符串。如果是这种情况,最好使用DzinX's回答。

答案 2 :(得分:12)

DZinX's answer是这个问题的绝佳答案。我在寻找反函数时发现了这个问题。我发现这个工作:

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

我不确定这里的礼节,但我认为指向反函数的指针可能对像我这样的其他人有用。

答案 3 :(得分:6)

我想在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

答案 4 :(得分:5)

从1月1日开始减去:

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

答案 5 :(得分:5)

如果您有理由避免使用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

答案 6 :(得分:1)

此代码将日期作为输入参数并返回一年中的日期。

from datetime import datetime
date = raw_input("Enter date: ")  ## format is 02-02-2016
adate = datetime.datetime.strptime(date,"%d-%m-%Y")
day_of_year = adate.timetuple().tm_yday
day_of_year