Конвертировать год / месяц / день в день года в Python
Я использую модуль Python "datetime", т. е.:
>>> import datetime
>>> today = datetime.datetime.now()
>>> print today
2009-03-06 13:24:58.857946
и я хотел бы вычислить день года, который чувствителен к високосным годам. например, День (6 марта 2009 года) - это 65-й день 2009 года. вот веб-калькулятор DateTime.
в любом случае, я вижу два варианта:
создать массив number_of_days_in_month = [31, 28,...], решить, если это високосный год, вручную суммировать дни
использовать значение datetime.timedelta, чтобы сделать предположение , а затем двоичный поиск правильного дня года:
.
>>> import datetime
>>> YEAR = 2009
>>> DAY_OF_YEAR = 62
>>> d = datetime.date(YEAR, 1, 1) + datetime.timedelta(DAY_OF_YEAR - 1)
Они оба чувствуют себя довольно неуклюжими, и у меня есть ощущение, что есть более "Питонский" способ расчета дня года. Любые идеи/предложения?
7 ответов:
не могли бы вы использовать
strftime?>>> import datetime >>> today = datetime.datetime.now() >>> print today 2009-03-06 15:37:02.484000 >>> today.strftime('%j') '065'Edit
как отмечено в комментариях, если вы хотите сделать сравнения или вычисления с этим числом, вам нужно будет преобразовать его в
int(), потому чтоstrftime()возвращает строку. Если это так, то вам лучше использовать 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Я не уверен в этикете здесь, но я думал, что указатель на обратную функцию может быть полезен для других, таких как я.
Я хочу представить производительность различных подходов, на 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
просто вычтите 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
этот код принимает дату в качестве входного аргумента и возвращает день года.
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
Comments