Python的作用還是比較的廣泛的,在日常生活中,應(yīng)用范圍也比較的廣泛,比如,我們可以去利用python,以此來獲取年月日等相關(guān)的一些信息,具體的內(nèi)容是什么呢?下面就給大家詳細的解答下。
這次介紹日期數(shù)據(jù)處理。
用python中的方法對日期數(shù)據(jù)進行處理,我們可以獲取很多有用的信息,比如年月日,星期,周次,季度等,這里分享工作和數(shù)據(jù)競賽30余種常用的轉(zhuǎn)換方法。
1計算日期的年月日時分秒,星期,周次…
用pandas的read_excel()方法讀取excel表數(shù)據(jù),將表格中"日期"列轉(zhuǎn)日期格式
import pandas as pd import numpy as np import datetime df=pd.read_excel('./日期問題.xlsx') #將日期列轉(zhuǎn)成日期格式 df['日期']=pd.to_datetime(df['日期'])
dt模塊可輕松獲取日期基本屬性
#轉(zhuǎn)年月日格式(字符串文本) df['年月日']=df['日期'].apply(lambda x:x.strftime('%Y%m%d')) df['年']=df['日期'].dt.year df['季度']=df['日期'].dt.quarter df['月']=df['日期'].dt.month df['日']=df['日期'].dt.day df['星期幾']=df['日期'].dt.dayofweek df['周次']=df['日期'].dt.week df['時']=df['日期'].dt.hour df['分']=df['日期'].dt.minute df['秒']=df['日期'].dt.second
2計算一年中的第幾天,第幾個10分鐘,日期轉(zhuǎn)數(shù)值
通過對天,時,分的四則運算將日期轉(zhuǎn)為序列數(shù)值數(shù)據(jù)
df['一年中的第幾天']=df['日期'].dt.dayofyear df['一天中的第幾分鐘']=df['日期'].apply(lambda x:x.minute+x.hour*60) df['一天中的第幾個10分鐘']=df['時']*6+df['分']//10 df['數(shù)值']=df["日期"].values.astype(np.int64)//10**9 #轉(zhuǎn)年月(數(shù)值) df['年月']=df['日期'].dt.year*100+df['日期'].dt.month
3判斷日期是否閏年,年初年末,月初月末…
apply()和lambda()方法使用.python中2個強大的高階函數(shù). df['是否閏年']=df['日期'].apply(lambda x:x.is_leap_year)#是否閏年 df['是否月初']=df['日期'].apply(lambda x:x.is_month_start)#是否月初 df['是否月末']=df['日期'].apply(lambda x:x.is_month_end)#月末 df['是否季節(jié)初']=df['日期'].apply(lambda x:x.is_quarter_start)#季度初 df['是否季節(jié)末']=df['日期'].apply(lambda x:x.is_quarter_end)#季度末 df['是否年初']=df['日期'].apply(lambda x:x.is_year_start)#年初 df['是否年尾']=df['日期'].apply(lambda x:x.is_year_end)#年內(nèi)末 df['是否周末']=df['日期'].apply(lambda x:True if x.dayofweek in[5,6]else False)#是否周末 df.loc[((df['時']>=8)&(df['時']<22)),'是否營業(yè)時間']=True
4字符串時段,季節(jié)
構(gòu)造字典,用map方法進行替換.
period_dict={ 23:'深夜',0:'深夜',1:'深夜', 2:'凌晨',3:'凌晨',4:'凌晨', 5:'早晨',6:'早晨',7:'早晨', 8:'上午',9:'上午',10:'上午',11:'上午', 12:'中午',13:'中午', 14:'下午',15:'下午',16:'下午',17:'下午', 18:'傍晚', 19:'晚上',20:'晚上',21:'晚上',22:'晚上', } df['時間段']=df['時'].map(period_dict) #一年中的哪個季度 season_dict={ 1:'春季',2:'春季',3:'春季', 4:'夏季',5:'夏季',6:'夏季', 7:'秋季',8:'秋季',9:'秋季', 10:'冬季',11:'冬季',12:'冬季', } df['季節(jié)']=df['月'].map(season_dict)
5for循環(huán)快捷計算
python中的getattr()方法
time_features=['year','month','quarter','week','day','dayofweek','dayofyear'] dtype=np.int16 for time_feature in time_features: df[time_feature]=getattr(df['日期'].dt,time_feature).astype(dtype)
6時間間隔天數(shù)計算
日期與一指定日期或者今天日期相比,計算間隔天數(shù)
#設(shè)置初始的時間 base_time=datetime.datetime.strptime('2021-06-01','%Y-%m-%d') #計算時間差 df['時間差']=df['日期'].apply(lambda x:x-base_time).dt.days #距離今天天數(shù) df['間隔天數(shù)']=list(map(lambda x:x.days,pd.to_datetime('today')-df['日期']))
補充:Python日期獲取今天及昨天的年月日等信息
import time from datetime import datetime,date,timedelta #當前日期 now_date=time.strftime("%Y-%m-%d%H:%M:%S",time.localtime()) print("now_date:{}".format(now_date)) #當前時間的年月日 year=datetime.now().year month=datetime.now().month day=datetime.now().day print(f"year:{year},month:{month},day:{day}") #昨天 month_yesterday=(date.today()+timedelta(days=-1)).month day_yesterday=(date.today()+timedelta(days=-1)).day print(f"month_yesterday:{month_yesterday},day_yesterday:{day_yesterday}") 輸出結(jié)果: now_date:2022-06-01 11:22:11 year:2022,month:6,day:1 month_yesterday:5,day_yesterday:31
總結(jié)
這篇文章就給大家介紹到這里了,希望可以為各位讀者帶來幫助。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/128393.html
摘要:實際上,如果直接將表示日期的字符串傳遞給構(gòu)造函數(shù),也會在后臺調(diào)用方法,例如下面的代碼跟前面的是等價的。構(gòu)造函數(shù)構(gòu)造函數(shù)會模仿但有一點不同的是,日期和時間都是基于本地時區(qū)而非來創(chuàng)建。兼容性問題啊其原因就是非標準日期格式。 一:Date類型介紹 要創(chuàng)建一個日期對象,使用new操作符和Date構(gòu)造函數(shù)即可: var now = new Date(); Date.parse()方法 其中Da...
摘要:本文是重溫基礎(chǔ)系列文章的第七篇。系列目錄復(fù)習資料資料整理個人整理重溫基礎(chǔ)語法和數(shù)據(jù)類型重溫基礎(chǔ)流程控制和錯誤處理重溫基礎(chǔ)循環(huán)和迭代重溫基礎(chǔ)函數(shù)重溫基礎(chǔ)表達式和運算符重溫基礎(chǔ)數(shù)字本章節(jié)復(fù)習的是中的時間對象,一些處理的方法。 本文是 重溫基礎(chǔ) 系列文章的第七篇。今日感受:做好自律。 系列目錄: 【復(fù)習資料】ES6/ES7/ES8/ES9資料整理(個人整理) 【重溫基礎(chǔ)】1.語法和數(shù)據(jù)類型...
摘要:類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。日期時間組件方法到目前為止,剩下還未介紹的類型的方法如下表所示,都是直接取得和設(shè)置日期值中特定部分的方法了。 Date類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來保存日期。在使用這種數(shù)據(jù)存儲格式的條件下,Date 類型保存的日...
摘要:請注意,觸發(fā)器將不會在上午點開始,僅在,,和請注意,一些調(diào)度要求太復(fù)雜,無法用單一觸發(fā)表示例如每上午至之間每分鐘,下午至晚上點之間每分鐘一次。在這種情況下的解決方案是簡單地創(chuàng)建兩個觸發(fā)器,并注冊它們來運行相同的作業(yè)。 表達式說明 Cron-Expressions 用于配置 CronTrigger的實例。Cron Expressions 是由七個子表達式組成的字符串,用于描述日程表的各個...
摘要:類型中的類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。類型保存的日期能夠精確到年月日之前或之后的年。和的輸出因瀏覽器不同而有所差異如年月日上午方法可用比較操作符來比較日期值。 Date 類型 ECMAScript 中的Date 類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來...
閱讀 923·2023-01-14 11:38
閱讀 895·2023-01-14 11:04
閱讀 756·2023-01-14 10:48
閱讀 2055·2023-01-14 10:34
閱讀 961·2023-01-14 10:24
閱讀 840·2023-01-14 10:18
閱讀 510·2023-01-14 10:09
閱讀 588·2023-01-14 10:02