파이썬에서 년 / 월 / 일을 일로 변환


127

Python datetime 모듈을 사용하고 있습니다 .

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

윤년에 민감한 날을 계산하고 싶습니다. 예를 들어 오늘 (2009 년 3 월 6 일)은 2009 년 65 일입니다. 여기에는 웹 기반 DateTime 계산기가 있습니다.

어쨌든 두 가지 옵션이 있습니다.

A. number_of_days_in_month 배열 = [31, 28, ...]을 만들고 윤년인지 확인하고 수동으로 요일을 합산하십시오.

B. datetime.timedelta올바른 일을 추측하고 이진 검색하는 데 사용하십시오.

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

이 둘은 꽤 어색한 느낌이 들며 나는 일을 계산하는 더 "Pythonic"방법이 있다고 생각합니다. 어떤 아이디어 / 제안?

답변:


255

매우 간단한 해결책이 있습니다.

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

13
아주 사소하고 논란의 여지가 있지만 추가하는 date.today()것보다는 datetime.now()작동 하는 것이 작동의 본질을 조금 더 강조합니다.
Jeremy

5
더 나은 아직 : time.localtime().tm_yday localtime ()이 산출하는 것이므로 날짜 시간을 시간 튜플로 변환 할 필요가 없습니다.
Mike Ellis

14
@MikeEllis 그러나이 솔루션은 날짜 시간이 오늘과 일치하지 않을 때 수행 할 작업을 보여줍니다.
리트

2
참고 : 1부터 시작합니다
Mehdi Nellen

1
반대로 바꾸려면 "2020 년의 26 일"이라는 숫자가 있는데 날짜를 "26-01-2020"으로 변환하고 싶습니다.
Sankar

43

사용할 수 strftime없습니까?

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

편집하다

주석에서 언급 했듯이이 숫자로 비교 또는 계산을 수행하려면 문자열을 반환 하기 int()때문에 로 변환해야 strftime()합니다. 이 경우 DzinX의 답변을 사용하는 것이 좋습니다 .


1
-1 : 이키. "오늘-1 월 1 일"알고리즘이 더 좋습니다. strftime의 '% j'에 대한 간단한 설명을 찾지 않고도 훨씬 깨끗하고 완벽합니다.
S.Lott

12
진심이야? 1 월 1 일이 어색하고 빼기 방법은 무엇입니까? strftime은 이유가 있습니다. 동의하지 않습니다. 이것은 내 의견으로는 깨끗합니다.
Paolo Bergantino

1
strftime을 사용하면 timetuple.tm_yday 멤버에서 숫자로 문자열을 생성하므로 간접적입니다. 출처를 읽으십시오. 계산 / 비교 전에 생성 된 문자열을 숫자로 변환해야하므로 왜 귀찮습니까?
tzot

2
파일 이름에 사용하기 위해 문자열에서 하루 중 하루가 필요한 경우 strftime이 훨씬 깨끗한 솔루션입니다.
captain_M

13

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

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
성능을 어떻게 계산 했습니까? 나는 time.time을 사용하려고 시도했으며 그 결과는 다음과 같습니다. def f () : (today-datetime.datetime (today.year, 1, 1)). days + 1 start = time.time (); 에프(); print ( 'Lapsed {}'. format (time.time ()-시작)); 랩스 5.221366882324219e-05 def f () : int (today.strftime ( '% j')); 시작 = time.time (); 에프(); print ( 'Lapsed {}'. format (time.time ()-시작)); 7.462501525878906e-05
ssoto

5

날짜에서 1 월 1 일을 빼십시오.

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

1
파올로에 대하여 아무것도하지만, 문자열 포맷보다 확실히 더 직접적인 자연 선택 --- 그래서 datetime.timedelta는, (물론, 초 및 마이크로뿐만 아니라) 일로 표시됩니다
zweiterlinde

1
d.toordinal ()-날짜 (d.year, 1, 1) .toordinal () + 1은 설명서에 따라 더 표준입니다. 전체 튜플을 생성하지 않고 허용되는 답변과 같습니다.
Dingle

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

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
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.