793

次のことを知りたい:日付(datetimeオブジェクト)が与えられた場合、対応する曜日は何ですか?

たとえば、日曜日は1日目、月曜日は2日目などです。

そして、入力が今日の日付のようなものである場合。

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

出力は多分6(金曜日なので)

4

27 に答える 27

1260

使用weekday()

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

ドキュメントから:

曜日を整数として返します。ここで、月曜日は0、日曜日は6です。

于 2012-03-23T22:26:41.767 に答える
366

英語で日付を知りたい場合:

from datetime import date
import calendar
my_date = date.today()
calendar.day_name[my_date.weekday()]  #'Wednesday'
于 2015-04-08T15:43:58.820 に答える
174

英語で日付を知りたい場合:

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

続きを読む: https ://docs.python.org/3/library/datetime.html#strftime-strptime-behavior

于 2018-07-25T10:07:41.803 に答える
81

date.weekday()月曜日が0、日曜日が6の場合に使用します

また

date.isoweekday()月曜日が1、日曜日が7の場合

于 2012-03-23T22:24:44.050 に答える
47

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"))
于 2012-03-23T22:36:21.947 に答える
34

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')
于 2013-06-15T05:18:28.043 に答える
16

文字列として日付がある場合は、パンダのタイムスタンプを使用して行う方が簡単な場合があります

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

出力:

4 Friday
于 2019-04-12T09:48:50.847 に答える
14

この問題を解決するための簡単なコードスニペットを次に示します

import datetime

intDay = datetime.date(year=2000, month=12, day=1).weekday()
days = ["Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"]
print(days[intDay])

出力は次のようになります。

Friday
于 2020-07-21T16:46:27.780 に答える
12

これは、日付が日時オブジェクトである場合の解決策です。

import datetime
def dow(date):
    days=["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
    dayNumber=date.weekday()
    print days[dayNumber]
于 2015-10-29T14:01:24.003 に答える
9

timeStamp :文字列変数、YYYY-MM-DD HH:MM:SSがあるとします

ステップ1:ブローコードを使用してdateTime関数に変換します。

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

ステップ2:これで、以下のように必要なすべての機能を抽出できます。これにより、フィルド時間、月、曜日、年、日付ごとに新しい列が作成されます。

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)
于 2019-02-20T05:49:53.147 に答える
8

datetimeライブラリでstrptime()でエラーが発生することがあるため、dateutilライブラリに切り替えました。これがあなたがそれを使うことができる方法の例です:

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

これから得られる出力はです'Mon'。「月曜日」として出力する場合は、次を使用します。

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

これは私にとって非常に迅速に機能しました。曜日番号の代わりに曜日名を保存したかったので、日時ライブラリの使用中に問題が発生しました。また、日時ライブラリを使用する際の形式に問題がありました。これで問題がなければ、素晴らしいです!もしそうなら、それはより単純な構文も持っているので、あなたは間違いなくこれに行くことができます。お役に立てれば。

于 2017-03-12T00:01:28.890 に答える
7

日、月、年が与えられていると仮定すると、次のことができます。

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)
于 2014-04-22T22:38:14.487 に答える
6

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
于 2015-05-11T17:59:41.793 に答える
5

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)]
于 2017-12-22T03:51:51.927 に答える
4
import datetime
int(datetime.datetime.today().strftime('%w'))+1

これにより、実際の日数がわかります-1 =日曜日、2=月曜日など...

于 2019-05-20T09:10:46.683 に答える
4

これは曜日のコメントである必要はありません。
このコードをお勧めします〜!

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
于 2021-01-21T10:23:16.317 に答える
3

日曜日を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
于 2014-05-09T01:47:36.960 に答える
3

私たちはパンダの助けを借りることができます:

import pandas as pd

上記の問題で述べたように、私たちは次のことをしています。

datetime(2017, 10, 20)

jupyterノートブックでこの行を実行すると、次のような出力が得られます。

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'

Pandasデータフレームに日付列がある場合:

ここで、次のような日付列を持つpandasデータフレームがあるとします。pdExampleDataFrame['Dates']。head(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
于 2019-01-23T07:39:50.913 に答える
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
于 2019-02-03T18:04:40.523 に答える
3

日付の範囲(Date)を持つ列を生成し、最初の列に移動して曜日(Week Day)を割り当てる列を生成する場合は、次のようにします(からの範囲の日付を使用します2008-01-012020-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 Day0から6まで変化します。ここで、0は月曜日に対応し、6は日曜日に対応します。

于 2020-07-06T08:51:34.927 に答える
2

リトルエンディアンの文字列日付のリストを次のように変換する方法は次の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"))
于 2017-07-10T02:05:28.590 に答える
2

シンプルでわかりやすく、まだ言及されていないオプション:

import datetime
...
givenDateObj = datetime.date(2017, 10, 20)
weekday      = givenDateObj.isocalendar()[2] # 5
weeknumber   = givenDateObj.isocalendar()[1] # 42
于 2020-08-11T00:36:18.177 に答える
1

Canlendarモジュールの使用

import calendar
a=calendar.weekday(year,month,day)
days=["MONDAY","TUESDAY","WEDNESDAY","THURSDAY","FRIDAY","SATURDAY","SUNDAY"]
print(days[a])
于 2018-02-21T18:34:11.603 に答える
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)
于 2018-03-04T08:18:09.643 に答える
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.")
于 2020-06-10T05:30:33.110 に答える
-1
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
于 2019-12-27T14:36:34.047 に答える
-2

このコードを使用します:

import pandas as pd
from datetime import datetime
print(pd.DatetimeIndex(df['give_date']).day)
于 2019-09-09T16:21:23.273 に答える