from - Convierta año/mes/día en día del año en Python
python datetime to timestamp (7)
¿No podrías usar strftime
?
>>> import datetime
>>> today = datetime.datetime.now()
>>> print today
2009-03-06 15:37:02.484000
>>> today.strftime(''%j'')
''065''
Editar
Como se señala en los comentarios, si desea hacer comparaciones o cálculos con este número, debería convertirlo a int()
porque strftime()
devuelve una cadena. Si ese es el caso, es mejor que DzinX''s respuesta DzinX''s .
Estoy usando el módulo Python "datetime", es decir:
>>> import datetime
>>> today = datetime.datetime.now()
>>> print today
2009-03-06 13:24:58.857946
y me gustaría calcular el día del año que es sensible a los años bisiestos. por ejemplo, oday (6 de marzo de 2009) es el día 65 de 2009. Aquí está la calculadora DateTime basada en la web .
De todos modos, veo dos opciones:
Cree una matriz number_of_days_in_month = [31, 28, ...], decida si es un año bisiesto, resuma manualmente los días
Use datetime.timedelta para hacer una adivinación y luego búsqueda binaria para el día correcto del año:
.
>>> import datetime
>>> YEAR = 2009
>>> DAY_OF_YEAR = 62
>>> d = datetime.date(YEAR, 1, 1) + datetime.timedelta(DAY_OF_YEAR - 1)
Ambos se sienten bastante torpes y tengo la corazonada de que hay una forma más "pitonica" de calcular el día del año. ¿Alguna idea / sugerencia?
Este código toma una fecha como argumento de entrada y devuelve el día del año.
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
Hay una solución muy simple:
day_of_year = datetime.now().timetuple().tm_yday
Quiero presentar el rendimiento de diferentes enfoques, en Python 3.4, Linux x64. Extracto del perfilador de línea:
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
(...)
Entonces, lo más eficiente es
yday = (period_end - date(period_end.year, 1, 1)).days
Si tiene motivos para evitar el uso del módulo de fecha y hora, estas funciones funcionarán.
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
Solo reste el 1 de enero de la fecha:
import datetime
today = datetime.datetime.now()
day_of_year = (today - datetime.datetime(today.year, 1, 1)).days + 1
La respuesta de DZinX es una gran respuesta para la pregunta. Encontré esta pregunta mientras buscaba la función inversa. Encontré esto para trabajar:
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
No estoy seguro de la etiqueta por aquí, pero pensé que un puntero a la función inversa podría ser útil para otros como yo.