在Python進行資料分析時,依照日期進行分組總和也是被需要的,例如會找到銷售量的周期性法則。
那麼在用Python進行資料統計之前,就需要額外增加一步:從指定的日期當中取得星期幾。例如2022年2月22日,還剛好是正月廿二星期二,於是乎這天登記結婚的人特別多。本文以2022-02-22為例,示範Python取得指定日期是「星期幾」的6種方法!
datetime模組是一個Python內建函式庫,無需再進行pip安裝,它除了可以顯示日期和時間之外,還可以進行日期和時間的運算以及格式化。
datetime模組中的方法weekday()可用於檢索星期幾,結果傳回0-6之間的整數,用來代表「星期一」到「星期日」。
在互動式環境中輸入以下指令:
from datetime import datetime datetime.date(2022, 2, 22).weekday()
輸出:
1
在程式碼中,datetime模組會先將由年、月和日組成的日期轉換為datetime日期。然後weekday()方法取得「2022-02-22」這天是星期二。
但是根據我們國內的習慣,總不能直接輸出1吧。所以我們可以先自訂一個包含中文「星期幾」的列表,再透過索引的方式來傳回一個中文的星期幾。
在互動式環境中輸入以下指令:
week_list = ["星期一","星期二","星期三","星期四","星期五","星期六","星期日"] week_list[datetime.date(2022, 2, 22).weekday()]
輸出:
'星期二'
這樣結果便是直接是星期二了。
isoweekday()方法與前一個weekday()方法的工作原理類似,最大的區別是它傳回1-7之間的整數,用來代表「星期一」到「星期日」。
在互動式環境中輸入以下指令:
import datetime datetime.date(2022, 2, 22).isoweekday()
輸出:
2
這次輸出的結果便直接是「星期2」了。
如果你想直接輸出日期的英文週名,不妨試試strftime()方法。
利用strftime()方法可以將datetime物件顯示為字串。我們其實對日期格式轉換為字串格式非常熟悉,例如strftime('%b-%m-%y %H:%M:%S'),只需將其中的指令改為%A,即可得到日期是星期幾。
在互動式環境中輸入以下指令:
import datetime datetime.date(2022, 2, 22).strftime("%A")
輸出:
'Tuesday'
如果將程式碼中的%A改為%a,則輸出的是星期幾的簡寫。
datetime.date(2022, 2, 22).strftime("%a")
輸出:
'Tue'
在Python中calendar日曆模組也是一個內建函式庫,為我們對行事曆做處理提供了很多方法,使用起來非常方便,我們可以使用它來製作日曆/週曆等等。同樣,它也提供了weekday()和day_name()方法來查詢指定日期是星期幾。
在互動式環境中輸入以下指令:
import calendar calendar.weekday(2022, 2, 22)
輸出:
1
這與前文第一個方法的datetime模組weekday()方法是一模一樣的。
如果你想直接輸出日期的英文週名,calendar日曆模組也有方法可以實現。
import datetime import calendar date_week = datetime.date(2022, 2, 22).weekday() calendar.day_name[date_week]
輸出:
'Tuesday'
datetime模組也有一些限制,例如處理時區問題等等。而pendulum模組是這個第三方開源函式庫,可以解決內建datetime模組的所有問題。
#https://www.php.cn/link/ebc03fa648c2cd7da9d63b9ed835664e
#當然,它也有方法可以輸出指定日期是星期幾。
在互動式環境中輸入以下指令:
import pendulum pendulum.parse('2022-02-22').day_of_week
輸出:
2
輸出的結果直接是「星期2」。
最後,最後,我要說一個自己最常用的方法。因為小五平時主要在Pandas中處理數據,那么生成「星期」列肯定會優先考慮Pandas中的方法。
Series.dt可用於以datetimelike的形式存取序列的值並傳回幾個屬性。 Series.dt.day_name()函數傳回具有指定語言環境的DateTimeIndex的日期名稱。
在互動式環境中輸入如下指令:
import pandas as pd from datetime import datetime df = pd.DataFrame({ "name": ["张三", "李四", "朱五"], "date": [datetime(2022, 2, 21), datetime(2022, 2, 22), datetime(2022, 2, 23)]}) df
輸出如下圖所示:
df["week_num1"] = df["date"].dt.dayofweek df["week_num2"] = df["date"].dt.weekday df["week_name"] = df["date"].dt.day_name() df
輸出如下圖所示:
在今天的文章中,我們一共介紹了從指定的日期當中取得星期幾的6中方法。
希望我的分享對你有幫助,看到文末的小夥伴,麻煩給右下角點個讚再走吧~
以上是超全! Python取得某一日期是「星期幾」的六種方法!的詳細內容。更多資訊請關注PHP中文網其他相關文章!