资讯专栏INFORMATION COLUMN

教你用python从日期中获取年、月、日和星期等30种信息

89542767 / 2130人阅读

  Python的作用还是比较的广泛的,在日常生活中,应用范围也比较的广泛,比如,我们可以去利用python,以此来获取年月日等相关的一些信息,具体的内容是什么呢?下面就给大家详细的解答下。


  这次介绍日期数据处理。


  用python中的方法对日期数据进行处理,我们可以获取很多有用的信息,比如年月日,星期,周次,季度等,这里分享工作和数据竞赛30余种常用的转换方法。


  1计算日期的年月日时分秒,星期,周次…


  用pandas的read_excel()方法读取excel表数据,将表格中"日期"列转日期格式


  import pandas as pd
  import numpy as np
  import datetime
  df=pd.read_excel('./日期问题.xlsx')
  #将日期列转成日期格式
  df['日期']=pd.to_datetime(df['日期'])

01.png

  dt模块可轻松获取日期基本属性


  #转年月日格式(字符串文本)
  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分钟,日期转数值


  通过对天,时,分的四则运算将日期转为序列数值数据


  df['一年中的第几天']=df['日期'].dt.dayofyear
  df['一天中的第几分钟']=df['日期'].apply(lambda x:x.minute+x.hour*60)
  df['一天中的第几个10分钟']=df['时']*6+df['分']//10
  df['数值']=df["日期"].values.astype(np.int64)//10**9
  #转年月(数值)
  df['年月']=df['日期'].dt.year*100+df['日期'].dt.month

03.png

  3判断日期是否闰年,年初年末,月初月末…


  apply()和lambda()方法使用.python中2个强大的高阶函数.
  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['是否季节初']=df['日期'].apply(lambda x:x.is_quarter_start)#季度初
  df['是否季节末']=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)#年内末
  df['是否周末']=df['日期'].apply(lambda x:True if x.dayofweek in[5,6]else False)#是否周末
  df.loc[((df['时']>=8)&(df['时']<22)),'是否营业时间']=True

04.png

  4字符串时段,季节


  构造字典,用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['季节']=df['月'].map(season_dict)

  

05.png

      5for循环快捷计算


  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时间间隔天数计算


  日期与一指定日期或者今天日期相比,计算间隔天数


  #设置初始的时间
  base_time=datetime.datetime.strptime('2021-06-01','%Y-%m-%d')
  #计算时间差
  df['时间差']=df['日期'].apply(lambda x:x-base_time).dt.days
  #距离今天天数
  df['间隔天数']=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}")
  输出结果:
  now_date:2022-06-01 11:22:11
  year:2022,month:6,day:1
  month_yesterday:5,day_yesterday:31


  总结


  这篇文章就给大家介绍到这里了,希望可以为各位读者带来帮助。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/128393.html

相关文章

  • JS基础篇--日期Date详解与实例扩展

    摘要:实际上,如果直接将表示日期的字符串传递给构造函数,也会在后台调用方法,例如下面的代码跟前面的是等价的。构造函数构造函数会模仿但有一点不同的是,日期和时间都是基于本地时区而非来创建。兼容性问题啊其原因就是非标准日期格式。 一:Date类型介绍 要创建一个日期对象,使用new操作符和Date构造函数即可: var now = new Date(); Date.parse()方法 其中Da...

    Apollo 评论0 收藏0
  • 【重温基础】7.时间对象

    摘要:本文是重温基础系列文章的第七篇。系列目录复习资料资料整理个人整理重温基础语法和数据类型重温基础流程控制和错误处理重温基础循环和迭代重温基础函数重温基础表达式和运算符重温基础数字本章节复习的是中的时间对象,一些处理的方法。 本文是 重温基础 系列文章的第七篇。今日感受:做好自律。 系列目录: 【复习资料】ES6/ES7/ES8/ES9资料整理(个人整理) 【重温基础】1.语法和数据类型...

    YuboonaZhang 评论0 收藏0
  • 详解日期(Date)引用类型

    摘要:类型使用自,国际协调时间年月日午夜零时开始经过的毫秒数来保存日期。日期时间组件方法到目前为止,剩下还未介绍的类型的方法如下表所示,都是直接取得和设置日期值中特定部分的方法了。 Date类型使用自UTC(Coordinated Universal Time,国际协调时间)1970 年1 月1 日午夜(零时)开始经过的毫秒数来保存日期。在使用这种数据存储格式的条件下,Date 类型保存的日...

    Shisui 评论0 收藏0
  • Quartz学习之Cron Expressions表达式

    摘要:请注意,触发器将不会在上午点开始,仅在,,和请注意,一些调度要求太复杂,无法用单一触发表示例如每上午至之间每分钟,下午至晚上点之间每分钟一次。在这种情况下的解决方案是简单地创建两个触发器,并注册它们来运行相同的作业。 表达式说明 Cron-Expressions 用于配置 CronTrigger的实例。Cron Expressions 是由七个子表达式组成的字符串,用于描述日程表的各个...

    Mr_zhang 评论0 收藏0
  • JavaScript引用类型——“Date类型”的注意要点

    摘要:类型中的类型使用自,国际协调时间年月日午夜零时开始经过的毫秒数来保存日期。类型保存的日期能够精确到年月日之前或之后的年。和的输出因浏览器不同而有所差异如年月日上午方法可用比较操作符来比较日期值。 Date 类型 ECMAScript 中的Date 类型使用自UTC(Coordinated Universal Time,国际协调时间)1970 年1 月1 日午夜(零时)开始经过的毫秒数来...

    brianway 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<