成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

教你用python從日期中獲取年、月、日和星期等30種信息

89542767 / 2192人閱讀

  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['日期'])

01.png

  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

02.png

  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

03.png

  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

04.png

  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)

  

05.png

      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)

06.png

  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['日期']))

07.png

  補充: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

相關(guān)文章

  • JS基礎(chǔ)篇--日期Date詳解與實例擴展

    摘要:實際上,如果直接將表示日期的字符串傳遞給構(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...

    Apollo 評論0 收藏0
  • 【重溫基礎(chǔ)】7.時間對象

    摘要:本文是重溫基礎(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ù)類型...

    YuboonaZhang 評論0 收藏0
  • 詳解日期(Date)引用類型

    摘要:類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。日期時間組件方法到目前為止,剩下還未介紹的類型的方法如下表所示,都是直接取得和設(shè)置日期值中特定部分的方法了。 Date類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來保存日期。在使用這種數(shù)據(jù)存儲格式的條件下,Date 類型保存的日...

    Shisui 評論0 收藏0
  • Quartz學(xué)習之Cron Expressions表達式

    摘要:請注意,觸發(fā)器將不會在上午點開始,僅在,,和請注意,一些調(diào)度要求太復(fù)雜,無法用單一觸發(fā)表示例如每上午至之間每分鐘,下午至晚上點之間每分鐘一次。在這種情況下的解決方案是簡單地創(chuàng)建兩個觸發(fā)器,并注冊它們來運行相同的作業(yè)。 表達式說明 Cron-Expressions 用于配置 CronTrigger的實例。Cron Expressions 是由七個子表達式組成的字符串,用于描述日程表的各個...

    Mr_zhang 評論0 收藏0
  • JavaScript引用類型——“Date類型”的注意要點

    摘要:類型中的類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。類型保存的日期能夠精確到年月日之前或之后的年。和的輸出因瀏覽器不同而有所差異如年月日上午方法可用比較操作符來比較日期值。 Date 類型 ECMAScript 中的Date 類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來...

    brianway 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<