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