날짜를 지정하면 요일을 어떻게 알 수 있나요?
다음 사항을 알고 싶습니다.날짜를 지정해주세요)datetime
object)의 요일은 무엇입니까?
예를 들어 일요일은 첫째 날이고 월요일은 둘째 날입니다.등등
그리고 입력된 날짜가 오늘 날짜인지 확인합니다.
예
>>> today = datetime.datetime(2017, 10, 20)
>>> today.get_weekday() # what I look for
출력은 아마6
(금요일이니까)
사용하다weekday()
:
>>> import datetime
>>> datetime.datetime.today()
datetime.datetime(2012, 3, 23, 23, 24, 55, 173504)
>>> datetime.datetime.today().weekday()
4
매뉴얼에서 다음 항목을 참조하십시오.
요일을 정수로 반환합니다.여기서 월요일은 0, 일요일은 6입니다.
영어로 날짜를 입력하려면:
from datetime import date
import calendar
my_date = date.today()
calendar.day_name[my_date.weekday()] #'Wednesday'
영어로 날짜를 입력하려면:
from datetime import datetime
datetime.today().strftime('%A')
'Wednesday'
상세내용 : https://docs.python.org/3/library/datetime.html#strftime-strptime-behavior
월요일이 0이고 일요일이 6일 때 사용
또는
date.isoweekday()
월요일이 1이고 일요일이 7일 때
CodeChef 질문으로 해결했습니다.
import datetime
dt = '21/03/2012'
day, month, year = (int(x) for x in dt.split('/'))
ans = datetime.date(year, month, day)
print (ans.strftime("%A"))
1700/1/1 이후 날짜에 Import된 솔루션
def weekDay(year, month, day):
offset = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]
week = ['Sunday',
'Monday',
'Tuesday',
'Wednesday',
'Thursday',
'Friday',
'Saturday']
afterFeb = 1
if month > 2: afterFeb = 0
aux = year - 1700 - afterFeb
# dayOfWeek for 1700/1/1 = 5, Friday
dayOfWeek = 5
# partial sum of days betweem current date and 1700/1/1
dayOfWeek += (aux + afterFeb) * 365
# leap year correction
dayOfWeek += aux / 4 - aux / 100 + (aux + 100) / 400
# sum monthly and day offsets
dayOfWeek += offset[month - 1] + (day - 1)
dayOfWeek %= 7
return dayOfWeek, week[dayOfWeek]
print weekDay(2013, 6, 15) == (6, 'Saturday')
print weekDay(1969, 7, 20) == (0, 'Sunday')
print weekDay(1945, 4, 30) == (1, 'Monday')
print weekDay(1900, 1, 1) == (1, 'Monday')
print weekDay(1789, 7, 14) == (2, 'Tuesday')
날짜를 끈으로 묶으면 판다의 타임스탬프를 이용해서 하는 게 더 쉬울 것 같아요.
import pandas as pd
df = pd.Timestamp("2019-04-12")
print(df.dayofweek, df.weekday_name)
출력:
4 Friday
이 문제를 해결하기 위한 간단한 코드 조각입니다.
import datetime
intDay = datetime.date(year=2000, month=12, day=1).weekday()
days = ["Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"]
print(days[intDay])
출력은 다음과 같습니다.
Friday
이것은 날짜가 datetime 객체일 경우 해결 방법입니다.
import datetime
def dow(date):
days=["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
dayNumber=date.weekday()
print days[dayNumber]
datetime 라이브러리에서 strptime() 에러가 발생할 수 있기 때문에 dateutil 라이브러리로 전환했습니다.사용 방법의 예를 다음에 나타냅니다.
from dateutil import parser
parser.parse('January 11, 2010').strftime("%a")
여기서 얻을 수 있는 출력은'Mon'
출력을 'Monday'로 하려면 다음 명령을 사용합니다.
parser.parse('January 11, 2010').strftime("%A")
이건 나한테 꽤 빨리 먹혔어.평일 번호 대신 평일 이름을 저장하려고 했는데, 날짜 라이브러리 사용 형식 때문에 문제가 발생했습니다.문제가 없다면 다행이군요!만약 그렇다면, 당신은 이것이 더 간단한 구문도 가지고 있기 때문에, 이것을 확실히 추천합니다.이게 도움이 됐으면 좋겠다.
timeStamp: String 변수, YYY-MM-DD HH가 있다고 가정합니다.SS
스텝 1: 블로 코드의 date Time 함수로 변환...
df['timeStamp'] = pd.to_datetime(df['timeStamp'])
스텝 2 : 다음과 같이 필요한 기능을 모두 추출할 수 있습니다.이것에 의해, 각 fild-hour, month, day of week, year, date의 새로운 컬럼이 작성됩니다.
df['Hour'] = df['timeStamp'].apply(lambda time: time.hour)
df['Month'] = df['timeStamp'].apply(lambda time: time.month)
df['Day of Week'] = df['timeStamp'].apply(lambda time: time.dayofweek)
df['Year'] = df['timeStamp'].apply(lambda t: t.year)
df['Date'] = df['timeStamp'].apply(lambda t: t.day)
일, 월 및 연도가 주어진 경우 다음을 수행할 수 있습니다.
import datetime
DayL = ['Mon','Tues','Wednes','Thurs','Fri','Satur','Sun']
date = DayL[datetime.date(year,month,day).weekday()] + 'day'
#Set day, month, year to your value
#Now, date is set as an actual day, not a number from 0 to 6.
print(date)
datetime 모듈을 사용하지 않을 이유가 있는 경우 이 기능은 작동합니다.
주: 율리우스력에서 그레고리력으로의 변화는 1582년에 일어난 것으로 추정됩니다.이것이 관심 있는 달력에 해당되지 않는 경우 year > 1582: 의 행을 적절히 변경합니다.
def dow(year,month,day):
""" day of week, Sunday = 1, Saturday = 7
http://en.wikipedia.org/wiki/Zeller%27s_congruence """
m, q = month, day
if m == 1:
m = 13
year -= 1
elif m == 2:
m = 14
year -= 1
K = year % 100
J = year // 100
f = (q + int(13*(m + 1)/5.0) + K + int(K/4.0))
fg = f + int(J/4.0) - 2 * J
fj = f + 5 - J
if year > 1582:
h = fg % 7
else:
h = fj % 7
if h == 0:
h = 7
return h
이치노
이 코드를 추천합니다~!
import datetime
DAY_OF_WEEK = {
"MONDAY": 0,
"TUESDAY": 1,
"WEDNESDAY": 2,
"THURSDAY": 3,
"FRIDAY": 4,
"SATURDAY": 5,
"SUNDAY": 6
}
def string_to_date(dt, format='%Y%m%d'):
return datetime.datetime.strptime(dt, format)
def date_to_string(date, format='%Y%m%d'):
return datetime.datetime.strftime(date, format)
def day_of_week(dt):
return string_to_date(dt).weekday()
dt = '20210101'
if day_of_week(dt) == DAY_OF_WEEK['SUNDAY']:
None
고객님이 고객님께만 의존하지 않으신다면datetime
"displays",calendar
코드를 에 나타냅니다.예를 들어, 요일 코드를 다음에 나타냅니다.
calendar.weekday(2017,12,22);
그리고 이렇게 하면 하루 그 자체를 얻을 수 있습니다.
days = ["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
days[calendar.weekday(2017,12,22)]
또는 하나의 라이너처럼 비단뱀 스타일로:
["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"][calendar.weekday(2017,12,22)]
import datetime
int(datetime.datetime.today().strftime('%w'))+1
1 = 일요일, 2 = 월요일 등 실제 요일 번호가 표시됩니다.
일요일을 1에서 토요일을 7로 하는 것이 질문에 대한 가장 간단한 해결책입니다.
datetime.date.today().toordinal()%7 + 1
모든 것:
import datetime
today = datetime.date.today()
sunday = today - datetime.timedelta(today.weekday()+1)
for i in range(7):
tmp_date = sunday + datetime.timedelta(i)
print tmp_date.toordinal()%7 + 1, '==', tmp_date.strftime('%A')
출력:
1 == Sunday
2 == Monday
3 == Tuesday
4 == Wednesday
5 == Thursday
6 == Friday
7 == Saturday
우리는 판다를 도울 수 있다.
import pandas as pd
위의 문제에서 언급한 바와 같이 다음과 같은 문제가 있습니다.
datetime(2017, 10, 20)
주피터 노트북에서 이 행을 실행하면 다음과 같은 출력이 나타납니다.
datetime.datetime(2017, 10, 20, 0, 0)
weekday() 및 weekday_name 사용:
평일 정수 형식을 사용하려면 다음을 사용합니다.
pd.to_datetime(datetime(2017, 10, 20)).weekday()
출력은 다음과 같습니다.
4
일요일, 월요일, 금요일 등의 요일 이름으로 사용할 수 있습니다.
pd.to_datetime(datetime(2017, 10, 20)).weekday_name
출력은 다음과 같습니다.
'Friday'
판다 데이터 프레임에 날짜 열이 있는 경우:
pdExampleDataFrame['Dates']와 같은 날짜 열이 있는 판다 데이터 프레임이 있다고 가정합니다.헤드(5)
0 2010-04-01
1 2010-04-02
2 2010-04-03
3 2010-04-04
4 2010-04-05
Name: Dates, dtype: datetime64[ns]
을 알고 '월요일 '화요일', '화요일', '화요일', '화요일' 을 쓰면 됩니다..weekday_name
음음음같 뭇매하다
pdExampleDataFrame.head(5)['Dates'].dt.weekday_name
출력은 다음과 같습니다.
0 Thursday
1 Friday
2 Saturday
3 Sunday
4 Monday
Name: Dates, dtype: object
이 Dates 컬럼에서 평일 정수를 원하는 경우 다음을 사용할 수 있습니다.
pdExampleDataFrame.head(5)['Dates'].apply(lambda x: x.weekday())
출력은 다음과 같습니다.
0 3
1 4
2 5
3 6
4 0
Name: Dates, dtype: int64
import datetime
import calendar
day, month, year = map(int, input().split())
my_date = datetime.date(year, month, day)
print(calendar.day_name[my_date.weekday()])
출력 샘플
08 05 2015
Friday
( 「」 「」 「」)를 가지는 을 생성하는 .Date
번째 하여 요일을 컬럼을 합니다( 「 」 」 「 」 「 」 「 」 「 」 「 」 「 」 「 」 Week Day
다음 작업을 수행합니다(다음 날짜부터 사용).2008-01-01
로로 합니다.2020-02-01
import pandas as pd
dr = pd.date_range(start='2008-01-01', end='2020-02-1')
df = pd.DataFrame()
df['Date'] = dr
df['Week Day'] = pd.to_datetime(dr).weekday
출력은 다음과 같습니다.
Week Day
~ 6 입니다, 은 일요일을 나타냅니다.0 ~ 6은일요일입니다0 ~ 6은 월요일, 6은 일요일입니다
을 엔디안 문자열 날짜로 하는 방법입니다.datetime
:
import datetime, time
ls = ['31/1/2007', '14/2/2017']
for d in ls:
dt = datetime.datetime.strptime(d, "%d/%m/%Y")
print(dt)
print(dt.strftime("%A"))
심플하고 간단하지만 아직 언급되지 않은 옵션:
import datetime
...
givenDateObj = datetime.date(2017, 10, 20)
weekday = givenDateObj.isocalendar()[2] # 5
weeknumber = givenDateObj.isocalendar()[1] # 42
중국 사용자인 경우 다음 패키지를 사용할 수 있습니다.https://github.com/LKI/chinese-calendar
import datetime
# 判断 2018年4月30号 是不是节假日
from chinese_calendar import is_holiday, is_workday
april_last = datetime.date(2018, 4, 30)
assert is_workday(april_last) is False
assert is_holiday(april_last) is True
# 或者在判断的同时,获取节日名
import chinese_calendar as calendar # 也可以这样 import
on_holiday, holiday_name = calendar.get_holiday_detail(april_last)
assert on_holiday is True
assert holiday_name == calendar.Holiday.labour_day.value
# 还能判断法定节假日是不是调休
import chinese_calendar
assert chinese_calendar.is_in_lieu(datetime.date(2006, 2, 1)) is False
assert chinese_calendar.is_in_lieu(datetime.date(2006, 2, 2)) is True
여기 새로운 방법이 있습니다.일요일은 0입니다.
from datetime import datetime
today = datetime(year=2022, month=6, day=17)
print(today.toordinal()%7) # 5
yesterday = datetime(year=1, month=1, day=1)
print(today.toordinal()%7) # 1
캔린더 모듈 사용
import calendar
a=calendar.weekday(year,month,day)
days=["MONDAY","TUESDAY","WEDNESDAY","THURSDAY","FRIDAY","SATURDAY","SUNDAY"]
print(days[a])
다음은 python3 구현입니다.
months = {'jan' : 1, 'feb' : 4, 'mar' : 4, 'apr':0, 'may':2, 'jun':5, 'jul':6, 'aug':3, 'sep':6, 'oct':1, 'nov':4, 'dec':6}
dates = {'Sunday':1, 'Monday':2, 'Tuesday':3, 'Wednesday':4, 'Thursday':5, 'Friday':6, 'Saterday':0}
ranges = {'1800-1899':2, '1900-1999':0, '2000-2099':6, '2100-2199':4, '2200-2299':2}
def getValue(val, dic):
if(len(val)==4):
for k,v in dic.items():
x,y=int(k.split('-')[0]),int(k.split('-')[1])
val = int(val)
if(val>=x and val<=y):
return v
else:
return dic[val]
def getDate(val):
return (list(dates.keys())[list(dates.values()).index(val)])
def main(myDate):
dateArray = myDate.split('-')
# print(dateArray)
date,month,year = dateArray[2],dateArray[1],dateArray[0]
# print(date,month,year)
date = int(date)
month_v = getValue(month, months)
year_2 = int(year[2:])
div = year_2//4
year_v = getValue(year, ranges)
sumAll = date+month_v+year_2+div+year_v
val = (sumAll)%7
str_date = getDate(val)
print('{} is a {}.'.format(myDate, str_date))
if __name__ == "__main__":
testDate = '2018-mar-4'
main(testDate)
import numpy as np
def date(df):
df['weekday'] = df['date'].dt.day_name()
conditions = [(df['weekday'] == 'Sunday'),
(df['weekday'] == 'Monday'),
(df['weekday'] == 'Tuesday'),
(df['weekday'] == 'Wednesday'),
(df['weekday'] == 'Thursday'),
(df['weekday'] == 'Friday'),
(df['weekday'] == 'Saturday')]
choices = [0, 1, 2, 3, 4, 5, 6]
df['week'] = np.select(conditions, choices)
return df
날짜를 DD-MM-YYY 형식으로 입력하는 코드는 '%d-%m-%Y'의 순서를 변경하고 구분 기호를 변경하여 입력 형식을 변경할 수 있습니다.
import datetime
try:
date = input()
date_time_obj = datetime.datetime.strptime(date, '%d-%m-%Y')
print(date_time_obj.strftime('%A'))
except ValueError:
print("Invalid date.")
다음 코드 사용:
import pandas as pd
from datetime import datetime
print(pd.DatetimeIndex(df['give_date']).day)
언급URL : https://stackoverflow.com/questions/9847213/how-do-i-get-the-day-of-week-given-a-date
'sourcecode' 카테고리의 다른 글
MySQL ON 중복 키 - 마지막 삽입 ID? (0) | 2022.09.18 |
---|---|
String 클래스는 + 연산자를 어떻게 덮어쓰나요? (0) | 2022.09.18 |
Python SQL 다른 테이블에서 일치하지 않는 항목을 찾는 방법 (0) | 2022.09.18 |
Node.js 응용 프로그램을 디버깅하려면 어떻게 해야 하나요? (0) | 2022.09.18 |
fprintf, printf, sprintf의 차이? (0) | 2022.09.18 |