ฉันจะได้รับวันในสัปดาห์กำหนดวันได้อย่างไร


589

ฉันต้องการค้นหาสิ่งต่อไปนี้: กำหนดวันที่ ( datetimeวัตถุ) วันที่สอดคล้องกันของสัปดาห์คืออะไร?

ตัวอย่างเช่นวันอาทิตย์เป็นวันแรกวันจันทร์: วันที่สอง .. เป็นต้น

แล้วถ้าอินพุทเป็นวันที่วันนี้

ตัวอย่าง

>>> today = datetime.datetime(2017, 10, 20)
>>> today.get_weekday()  # what I look for

ผลลัพธ์อาจจะ6(ตั้งแต่วันศุกร์)

คำตอบ:


937

ใช้weekday()( เอกสาร ):

>>> import datetime
>>> datetime.datetime.today()
datetime.datetime(2012, 3, 23, 23, 24, 55, 173504)
>>> datetime.datetime.today().weekday()
4

จากเอกสาร:

ส่งคืนวันในสัปดาห์ด้วยจำนวนเต็มโดยวันจันทร์เป็น 0 และวันอาทิตย์คือ 6


342
สิ่งสำคัญที่ควรทราบคือใน JavaScript 0 = วันอาทิตย์ Python เริ่มต้นด้วย 0 = วันจันทร์ สิ่งที่ฉันวิ่งเข้าไป, Front-End VS back-end ..
radtek

4
คณิตศาสตร์ในปฏิทินมักจะแย่เพราะคอมพิวเตอร์ไม่รู้ว่า PTO คืออะไร ในความพยายามที่จะหลีกเลี่ยงการสอนพวกเขาฉันขอแนะนำฟังก์ชั่นที่ทำให้งงซึ่งกำหนดว่าปัจจุบันเป็นวันหยุดหรือวันหยุดสุดสัปดาห์
meawoppl

11
อาจเป็นเพราะ OP บอกว่า "ยกตัวอย่างเช่น" "อะไรทำนองนี้" และ "อาจจะ"
Eugene

10
หากคุณต้องการให้วันอาทิตย์เป็นวันที่ 0:int(datetime.datetime.today().strftime('%w'))
mrooney

19
ในการเริ่มต้นจาก 1 เราสามารถใช้ isoweekday แทนการทำงานในวันธรรมดา 1 = วันจันทร์
Aman Kumar

288

หากคุณต้องการมีวันที่เป็นภาษาอังกฤษ:

from datetime import date
import calendar
my_date = date.today()
calendar.day_name[my_date.weekday()]  #'Wednesday'

1
นี่น่าจะเป็นคำตอบที่ดีที่สุดในการสร้างภาษาอังกฤษวันของสัปดาห์ ฉันเดาว่ามันไม่ได้เพิ่มขึ้นเพราะคำตอบคือ ~ 1 เดือนในขณะที่คำถามคือ ~ 3 ปี
Johnny Utahh

20
ฉันคิดว่ามันมีประสิทธิภาพมากกว่าที่จะทำmy_date.strftime('%A')
นาธานทิว

สิ่งนี้ช่วยชีวิตฉันไว้
Amol Bais



29

ฉันจะแก้ไขนี้สำหรับ 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"))

27

วิธีการแก้ปัญหาที่ไม่มีการนำเข้าสำหรับวันที่หลังจาก 1700/1/1

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')

ทำไมเราต้องทำ aux + 100/400 แทน aux / 400 คุณช่วยอธิบาย
หน่อยได้

python3: เพียงแค่เปลี่ยน '/' ทั้งหมดด้วย '//' ในฟังก์ชั่นด้านบนและมันจะทำงานเหมือนมีเสน่ห์
chabir

11

นี่เป็นวิธีแก้ปัญหาหากวันที่เป็นวัตถุวันที่และเวลา

import datetime
def dow(date):
    days=["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
    dayNumber=date.weekday()
    print days[dayNumber]

10

หากคุณมีวันที่เป็นสตริงมันอาจจะง่ายกว่าถ้าใช้ Timestamp ของแพนด้า

import pandas as pd
df = pd.Timestamp("2019-04-12")
print(df.dayofweek, df.weekday_name)

เอาท์พุท:

4 Friday

8

บางครั้งห้องสมุด datetime ให้ข้อผิดพลาดกับ strptime () ดังนั้นฉันจึงเปลี่ยนไปใช้ไลบรารี dateutil นี่คือตัวอย่างของวิธีการใช้งาน:

from dateutil import parser
parser.parse('January 11, 2010').strftime("%a")

'Mon'การแสดงผลที่คุณได้รับจากนี้คือ หากคุณต้องการให้ผลลัพธ์เป็น 'วันจันทร์' ให้ใช้สิ่งต่อไปนี้:

parser.parse('January 11, 2010').strftime("%A")

สิ่งนี้ใช้ได้กับฉันอย่างรวดเร็ว ฉันประสบปัญหาขณะใช้ห้องสมุด datetime เพราะฉันต้องการจัดเก็บชื่อวันทำงานแทนหมายเลขวันทำงานและรูปแบบจากการใช้ห้องสมุด datetime ทำให้เกิดปัญหา หากคุณไม่ได้มีปัญหากับเรื่องนี้ดี! หากคุณเป็นเช่นนั้นคุณสามารถลองทำสิ่งนี้ได้เพราะมันมีไวยากรณ์ที่ง่ายกว่าเช่นกัน หวังว่านี่จะช่วยได้


6

สมมติว่าคุณได้รับวันเดือนและปีคุณสามารถทำได้:

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)

ไม่จำเป็นต้องใช้อาร์เรย์ DayL เนื่องจากคุณสามารถรับชื่อวันได้โดยตรงโดยใช้strftime("%A")แทนweekday()
Lekr0

5

สมมติว่าคุณมีtimeStamp: ตัวแปรสตริง YYYY-MM-DD HH: MM: SS

ขั้นตอนที่ 1 : แปลงเป็นฟังก์ชั่น dateTime ด้วยรหัสเป่า ...

df['timeStamp'] = pd.to_datetime(df['timeStamp'])

ขั้นตอนที่ 2 : ตอนนี้คุณสามารถดึงคุณสมบัติที่ต้องการทั้งหมดได้ด้านล่างซึ่งจะสร้างคอลัมน์ใหม่สำหรับแต่ละ fild- ชั่วโมง, เดือน, วัน, สัปดาห์, ปี, วันที่

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)

4

หากคุณมีเหตุผลที่จะหลีกเลี่ยงการใช้โมดูล datetime ฟังก์ชั่นนี้จะใช้งานได้

หมายเหตุ: การเปลี่ยนแปลงจากปฏิทินจูเลียนเป็นปฏิทินเกรกอเรียนถือว่าเกิดขึ้นในปี 1582 ถ้าไม่เป็นจริงสำหรับปฏิทินที่คุณสนใจให้เปลี่ยนบรรทัดถ้าปี> 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

1
'A' สำหรับความพยายาม! คุณอาจย้ายข้อความสั่งเช่นเดียวกับที่กำหนดให้fgและfjภายในเงื่อนไขเพื่อป้องกันการคำนวณที่ไม่จำเป็น
Tom Russell

4

หากคุณไม่ได้พึ่งพาdatetimeโมดูลเพียงอย่างเดียว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)]

3

เราสามารถช่วยเหลือแพนด้า:

import pandas as pd

ดังกล่าวข้างต้นในปัญหาเรามี:

datetime(2017, 10, 20)

หากดำเนินการบรรทัดนี้ในสมุดบันทึก jupyter เรามีผลลัพธ์เช่นนี้:

datetime.datetime(2017, 10, 20, 0, 0)

ใช้วันทำงาน () และ weekday_name:

หากคุณต้องการวันธรรมดาในรูปแบบตัวเลขจำนวนเต็มให้ใช้:

pd.to_datetime(datetime(2017, 10, 20)).weekday()

ผลลัพธ์จะเป็น:

4

และหากคุณต้องการให้เป็นชื่อของวันเช่นวันอาทิตย์วันจันทร์วันศุกร์ ฯลฯ คุณสามารถใช้:

pd.to_datetime(datetime(2017, 10, 20)).weekday_name

ผลลัพธ์จะเป็น:

'Friday'

หากมีคอลัมน์วันที่ใน Pandas dataframe ให้ทำดังนี้:

ตอนนี้สมมติว่าคุณมีดาต้าดาต้าแพนด้ามีคอลัมน์วันเช่นนี้: 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

และถ้าเราต้องการจำนวนเต็มของวันทำงานจากคอลัมน์วันที่นี้เราก็สามารถใช้:

pdExampleDataFrame.head(5)['Dates'].apply(lambda x: x.weekday())

ผลลัพธ์จะมีลักษณะดังนี้:

0    3
1    4
2    5
3    6
4    0
Name: Dates, dtype: int64

3
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

3
import datetime
int(datetime.datetime.today().strftime('%w'))+1

ควรให้หมายเลขวันจริงของคุณ - 1 = วันอาทิตย์, 2 = วันจันทร์, ฯลฯ ...


ทำไมคุณจะใช้+1? เป็นเรื่องปกติที่การทำงานในสัปดาห์ของงูใหญ่เริ่มต้นที่ซันเดย์เป็น 0 และวันจันทร์เป็น 1
Nebulosar

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

คำถามถามถึงวันอาทิตย์ == 1, วันจันทร์ == 2, และวันศุกร์ == 6
วัว

2

นี่คือวิธีแปลงรายการวันที่เป็นวันที่

import datetime,time
ls={'1/1/2007','1/2/2017'}
dt=datetime.datetime.strptime(ls[1], "%m/%d/%Y")
print(dt)
print(dt.month)
print(dt.year)


1

นี่คือการใช้งาน 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)

0

ด้านล่างนี้คือรหัสสำหรับป้อนวันที่ในรูปแบบของ DD-MM-YYYY คุณสามารถเปลี่ยนรูปแบบการป้อนข้อมูลได้โดยเปลี่ยนลำดับของ '% 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.")


-1

นำเข้าจำนวนมากเป็น np

วันที่ def (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
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.