source

Python에서 연도/월/일을 연도의 요일로 변환

nicesource 2023. 6. 28. 21:48
반응형

Python에서 연도/월/일을 연도의 요일로 변환

모듈을 사용하고 있습니다. 예:

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

그리고 윤년을 고려하여 계산하고자 합니다. 예를 들어 오늘(2009년 3월 6일)은 2009년의 65번째 날입니다.

두 가지 옵션이 있습니다.

  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)
    

이 두 가지 모두 꽤 투박하게 느껴지고 저는 한 해의 하루를 계산하는 더 "파이토닉" 방식이 있다는 직감이 듭니다.아이디어/제안이 있습니까?

변환에 사용합니다.datetime개체에 대한 개체를 선택한 다음 해당 속성을 가져옵니다.

from datetime import datetime
day_of_year = datetime.now().timetuple().tm_yday  # returns 1 for January 1st

형식 문자열과 함께 사용할 수 있습니다.

>>> import datetime
>>> today = datetime.datetime.now()
>>> today.strftime('%j')
'065'

하지만 만약 당신이 이 숫자와 비교하거나 계산하기를 원한다면, 당신은 그것을 변환해야 할 것입니다.int()왜냐면strftime()문자열을 반환합니다.그렇다면, 당신은 DzinX의 답변을 사용하는 것이 좋습니다.

DZinX의 답변은 질문에 대한 훌륭한 답변입니다.저는 역함수인 줄리안 요일이 있는 날짜를 날짜 시간으로 변환하는 것을 찾다가 이 질문을 발견하고 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

또는 숫자:

import datetime
year,julian = [1936,77]
datetime.datetime(year, 1, 1)+datetime.timedelta(days=julian -1)

>>>> datetime.datetime(1936, 3, 17, 0, 0)

또는 일부 도메인에서 인기 있는 분수 1 기반 jdate와 함께:

jdate_frac = (datetime.datetime(1936, 3, 17, 13, 14, 15)-datetime.datetime(1936, 1, 1)).total_seconds()/86400+1
display(jdate_frac)

>>>> 77.5515625

year,julian = [1936,jdate_frac]
display(datetime.datetime(year, 1, 1)+datetime.timedelta(days=julian -1))

>>>> datetime.datetime(1936, 3, 17, 13, 14, 15)

이 근처의 에티켓은 잘 모르겠지만, 역기능에 대한 포인터가 저와 같은 다른 사람들에게 유용할 수도 있다고 생각했습니다.

사용을 피할 이유가 있는 경우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

저는 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

날짜에서 1월 1일을 빼면 됩니다.

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

간단하게 사용할 수 있습니다.dayofyear특정 연도의 요일을 제공하는 "filename"에서 제공하는 속성입니다.예를 들어.

data["day_of_year"] = data.Datetime.apply(lambda x:x.dayofyear)

언급URL : https://stackoverflow.com/questions/620305/convert-year-month-day-to-day-of-year-in-python

반응형