Как мне получить день недели, учитывая дату в Python?



Я хочу узнать следующее:
учитывая дату (datetime object), каков соответствующий день недели.



например, воскресенье-это первый день, понедельник: второй день.. и так далее



а затем, если вход что-то вроде сегодняшней даты.



пример



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


выход может быть 6 (поскольку пятница)

18331   20  

20 ответов:

использовать weekday() ( docs):

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

использовать date.weekday() или date.isoweekday().

решение без импорта для дат после 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')

Я решил это для 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")

это решение, если дата является объектом 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'. Если вы хотите, чтобы вывод был "понедельник", используйте следующее:

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

это работает для меня довольно быстро. У меня возникли проблемы при использовании библиотеки datetime, потому что я хотел сохранить имя дня недели вместо номера дня недели и формат от использования datetime библиотека вызывала проблемы. Если у вас нет проблем с этим, отлично! Если да, то вы можете эффективно пойти на это, поскольку он также имеет более простой синтаксис. Надеюсь, это поможет.

предполагая, что вам дан день, месяц и год, вы можете сделать:

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 модуль calendar может быть лучшей альтернативой. Это, например, предоставит вам коды дня:

calendar.weekday(2017,12,22);

и это даст вам тот день:

days = ["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
days[calendar.weekday(2017,12,22)]

или в стиле python, как один лайнер:

["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"][calendar.weekday(2017,12,22)]

Если у вас есть причины избегать использования модуля 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

Если вы хотите иметь дату на английском языке:

>>> from datetime import date
>>> datetime.datetime.today().strftime('%A')
'Wednesday'

подробнее: https://docs.python.org/2/library/datetime.html#strftime-strptime-behavior

чтобы получить воскресенье как 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

Использование Модуля Canlendar

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 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)
import datetime
a = datetime.datetime.today().weekday()
if a == 0:
    print("It's Monday.")
elif a == 1:
    print("It's Tuesday.")
elif a == 2:
    print("It's Wednesday.")
elif a == 3:
    print("It's Thursday.")
elif a ==4:
    print("It's Friday.")
elif a == 5:
    print("It's Saturday.")
elif a == 6:
    print("It's Sunday.")

# please like 

:)

Comments

  1. Pirockar
    Pirockar 5 лет назад
    <p>#задание №6<br />
    #Напишите функцию output(year), которая для заданного<br />
    #года year (тип int) возвращает чего было больше воскресений<br />
    #или сред в этом году. Функция должна выдавать: 0 - если было<br />
    #больше воскресений; 1 - если больше сред; 2 - если количество<br />
    #воскресений такое же, как и количество сред.<br />
    def output(year): #начало функции output<br />
        import datetime<br />
        s=0;<br />
        leapyear=0;<br />
        ans = datetime.date(year, 1, 1).strftime("%a")<br />
        print('######отладочная информация######')<br />
        print('первый день недели',ans)<br />
        #определяем колво дней нужных до среды<br />
        if (ans == "Mon") : s = 2 #Пон<br />
        elif (ans == "Tue") : s = 1 #Втор<br />
        elif (ans == "Wed") : s = 0 #Среда<br />
        elif (ans == "Thu") : s = 6<br />
        elif (ans == "Fri") : s = 5<br />
        elif (ans == "Sub") : s = 4<br />
        elif (ans == "Sun") : s = 3<br />
        print ('до среды осталось',s,'дней')<br />
        #определяем колводней нужных до воскресенья<br />
        if (ans == "Mon") : z = 6 #Пон<br />
        elif (ans == "Tue") : z = 5 #Втор<br />
        elif (ans == "Wed") : z = 4 #Сред<br />
        elif (ans == "Thu") : z = 3<br />
        elif (ans == "Fri") : z = 2<br />
        elif (ans == "Sub") : z = 1<br />
        elif (ans == "Sun") : z = 0 #Воскресенье<br />
        print ('до воскресенья осталось',z,'дней')<br />
        #Определяем високостный год<br />
        if (year % 4 == 0) : leapyear=366 #366 дней<br />
        else:  leapyear=365 #365 дней<br />
        print ('всего дней в году ',leapyear)<br />
        print ('сред ', (leapyear-s)//7) #делим на 7 а дробное число отбрасываем<br />
        print ('воскр ',(leapyear-z)//7) <br />
        print('#################################')<br />
        #считаем и выводим итог<br />
        if (((leapyear-z) // 7) &gt; ((leapyear-s)//7)) : print ('результат 0') #делим на 7 (это промежуток между повтором дня недели) а дробное число отбрасываем далее сравниваем больше ли воскресений<br />
        elif (((leapyear-z) // 7) &lt; ((leapyear-s)//7)) : print ('результат 1') #делим на 7 (это промежуток между повтором дня недели) а дробное число отбрасываем далее сравниваем больше ли сред<br />
        elif (((leapyear-z) // 7) == ((leapyear-s)//7)) : print ('результат 2') #делим на 7 (это промежуток между повтором дня недели) а дробное число отбрасываем далее сравниваем равенство ли<br />
        else: print ('какаято ошибка')<br />
        <br />
        <br />
    output(2015) #запускаем функцию output(с2015годом) работает от 1 до 9999, разные результы у 2014,2015,2017</p>
  2. Pirockar
    Pirockar 5 лет назад
    <p>#план такой: определяем первое число года первого месяца падает на какой день<br />
    #недели отсчитываем сколько дней нужно ждать до среды и отдельно до воскресенья<br />
    #далее выяснив сколько дней в году у нас есть минусуем их прожданными днями до<br />
    #первой среды и получившийся остаток дней так как мы на первой среде делим на<br />
    #промежуток в семь дней до следующей среды и выясняем сколько этих сред таким<br />
    #образом будет а дробный остаток выкидываем команда посчитать без остатка сразу<br />
    #это // например 366 // 7 = итог целое колво дней без кусочков но это если первый<br />
    #день сразу нужный попадется правда а теперь тоже самое дело для воскресений<br />
    #сколько до перв. воскр. прождали вычтеным из нашего запаса дней оставшихся<br />
    #до конца года пока ждали этого воскр. и делим узнаем колво воскресений в году<br />
    #так между ними всегда 7 дней же промежуток кажись. Теперь воплощаем план</p>
  3. Pirockar
    Pirockar 5 лет назад
    <p>здесь ошибка поэтому строку elif (ans == "Sub") : z = 1 нужно исправить на elif (ans == "Sat") : z = 1 и ещё вот эту строку elif (ans == "Sub") : s = 4 на вот эту строку нужно исправить elif (ans == "Sat") : s = 4 а то суббота по англ. в днях недели на subbath пишется а saturday (не саббат а сатуровый день)</p>

    <p>а так же после def output(year): #начало функции output<br />
        import datetime</p>

    <p>строки с s=0 и с leapyear=0 можно стереть это лишнее</p>
  4. Pirockar
    Pirockar 5 лет назад
    <p>нужно ещё кое что исправить строку if (((leapyear-z) // 7) &gt; ((leapyear-s)//7)) : print ('результат 0') на вот эту if (((leapyear-z) // 7) &gt; ((leapyear-s)//7)) : return (int(0))</p>

    <p>и ещё вот эту строку elif (((leapyear-z) // 7) &lt; ((leapyear-s)//7)) : print ('результат 1') на вот эту elif (((leapyear-z) // 7) &lt; ((leapyear-s)//7)) : return (int(1))</p>

    <p>и вот ещё эту строку elif (((leapyear-z) // 7) == ((leapyear-s)//7)) : print ('результат 2') на вот такую elif (((leapyear-z) // 7) == ((leapyear-s)//7)) : return (int(2))</p>

    <p>и ещё вот эту вот строку output(2015) на вот эту print('результат ', output(2015))</p>

    <p>готово<br />
    теперь функция возвращает значение а не выводит текстом поэтому она функция запускает в print то есть в руках которые это значение напишет так как если это значение не в одни руки не попадет то ничего с ним не будет и на экран руки которая напишет раз нету ничего не выведется а теперь работает прямо как надо по условию задания</p>