Конвертировать год / месяц / день в день года в Python - PullRequest
102 голосов
/ 06 марта 2009

Я использую модуль "datetime" на Python, т.е.

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

и я хотел бы вычислить день года, чувствительный к високосным годам. например сегодня (6 марта 2009 г.) - 65-й день 2009 г. Вот веб-калькулятор DateTime .

Во всяком случае, я вижу два варианта:

  1. Создать массив number_of_days_in_month = [31, 28, ...], решить, будет ли это високосный год, вручную суммировать дни

  2. Используйте datetime.timedelta, чтобы сделать предположение, а затем двоичный поиск правильного дня года:

.

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

Они оба чувствуют себя довольно неуклюже, и у меня есть внутреннее чувство, что есть более "Pythonic" способ вычисления дня года. Есть идеи / предложения?

Ответы [ 7 ]

214 голосов
/ 08 марта 2009

Существует очень простое решение:

from datetime import datetime
day_of_year = datetime.now().timetuple().tm_yday
33 голосов
/ 06 марта 2009

Не могли бы вы использовать strftime?

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

Редактировать

Как отмечено в комментариях, если вы хотите провести сравнение или вычисление с этим числом, вам придется преобразовать его в int(), поскольку strftime() возвращает строку. Если это так, вам лучше использовать DzinX's answer.

12 голосов
/ 23 октября 2012

Ответ DZinX - отличный ответ на вопрос. Я нашел этот вопрос, когда искал обратную функцию. Я нашел это на работу:

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

Я не уверен, что здесь есть этикет, но я подумал, что указатель на обратную функцию может быть полезен для других, таких как я.

6 голосов
/ 15 сентября 2014

Я хочу представить производительность разных подходов, на 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
5 голосов
/ 11 мая 2015

Если у вас есть основания избегать использования модуля 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
5 голосов
/ 06 марта 2009

Просто вычтите 1 января из даты:

import datetime
today = datetime.datetime.now()
day_of_year = (today - datetime.datetime(today.year, 1, 1)).days + 1
1 голос
/ 26 декабря 2017

Этот код принимает дату в качестве входного аргумента и возвращает день года.

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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...