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['日期'])
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
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
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
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)
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)
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['日期']))
补充: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
摘要:实际上,如果直接将表示日期的字符串传递给构造函数,也会在后台调用方法,例如下面的代码跟前面的是等价的。构造函数构造函数会模仿但有一点不同的是,日期和时间都是基于本地时区而非来创建。兼容性问题啊其原因就是非标准日期格式。 一:Date类型介绍 要创建一个日期对象,使用new操作符和Date构造函数即可: var now = new Date(); Date.parse()方法 其中Da...
摘要:本文是重温基础系列文章的第七篇。系列目录复习资料资料整理个人整理重温基础语法和数据类型重温基础流程控制和错误处理重温基础循环和迭代重温基础函数重温基础表达式和运算符重温基础数字本章节复习的是中的时间对象,一些处理的方法。 本文是 重温基础 系列文章的第七篇。今日感受:做好自律。 系列目录: 【复习资料】ES6/ES7/ES8/ES9资料整理(个人整理) 【重温基础】1.语法和数据类型...
摘要:类型使用自,国际协调时间年月日午夜零时开始经过的毫秒数来保存日期。日期时间组件方法到目前为止,剩下还未介绍的类型的方法如下表所示,都是直接取得和设置日期值中特定部分的方法了。 Date类型使用自UTC(Coordinated Universal Time,国际协调时间)1970 年1 月1 日午夜(零时)开始经过的毫秒数来保存日期。在使用这种数据存储格式的条件下,Date 类型保存的日...
摘要:请注意,触发器将不会在上午点开始,仅在,,和请注意,一些调度要求太复杂,无法用单一触发表示例如每上午至之间每分钟,下午至晚上点之间每分钟一次。在这种情况下的解决方案是简单地创建两个触发器,并注册它们来运行相同的作业。 表达式说明 Cron-Expressions 用于配置 CronTrigger的实例。Cron Expressions 是由七个子表达式组成的字符串,用于描述日程表的各个...
摘要:类型中的类型使用自,国际协调时间年月日午夜零时开始经过的毫秒数来保存日期。类型保存的日期能够精确到年月日之前或之后的年。和的输出因浏览器不同而有所差异如年月日上午方法可用比较操作符来比较日期值。 Date 类型 ECMAScript 中的Date 类型使用自UTC(Coordinated Universal Time,国际协调时间)1970 年1 月1 日午夜(零时)开始经过的毫秒数来...
阅读 889·2023-01-14 11:38
阅读 833·2023-01-14 11:04
阅读 685·2023-01-14 10:48
阅读 1888·2023-01-14 10:34
阅读 892·2023-01-14 10:24
阅读 750·2023-01-14 10:18
阅读 479·2023-01-14 10:09
阅读 519·2023-01-14 10:02