python 怎样将dataframe中的字符串日期转化为日期的方法

作者:跑马的汉子_ 时间:2022-09-14 16:21:49 

方法一:也是最简单的

直接使用pd.to_datetime函数实现


data['交易时间'] = pd.to_datetime(data['交易时间'])

方法二:

源自利用python进行数据分析P304

使用python的datetime包中的

strptime函数,datetime.strptime(value,'%Y/%M/%D')

strftime函数,datetime.strftime(‘%Y/%M/%D')

注意使用datetime包中后面的字符串匹配需要和原字符串的格式相同,才能转义过来,相当于yyyy-mm-dd格式的需要按照'%Y-%M-%D'来实现,而不是'%Y/%M/%D'


data['交易时间']=data['交易时间'].apply(lambda x:datetime.strptime(x,'%Y-%m-%d %H:%M:%S'))

注意到上面代码的'%Y-%m-%d %H:%M:%S'嘛?

这里的格式必须与原数值的格式一模一样才能转换,如果原数值里面是精确到时分秒的,那么你此处不写%H:%M:%S就没办法转换!!!切记


'''
获取指定日期的上个月
日期字符串和日期格式
'''
def getLastMonth(dtstr,dateformat):
d=datetime.strptime(dtstr, dateformat).date()
year = d.year
month = d.month
if month == 1 :#如果是本年1月的
month = 12
year -= 1
else :#如果是大于1月的
month -= 1
return (datetime(year,month,1)).strftime(dateformat)

'''
两个日期之间相差的月数
包括开始日期和结束日期的当天
日期字符串和日期格式
'''
def diffMonth(startDate,endDate,dateformat):
start=datetime.strptime(startDate, dateformat).date()
end=datetime.strptime(endDate, dateformat).date()

startYear=start.year
startMonth=start.month

endYear=end.year
endMonth=end.month

#如果是同年
if startYear==endYear:
diffmonths=endMonth-startMonth
#如果是上年
elif endYear-startYear==1:
diffmonths=12+endMonth-startMonth
#如果是大于1年
elif endYear-startYear>1:
years=endYear-startYear
diffmonths=(years-1)*12+12+endMonth-startMonth
#如果开始日期大约结束日期报错
elif endYear-startYear<0 or( endYear==startYear and endMonth-startMonth):
print 'enddate must greater than startdate'

return int(diffmonths+1)

来源:https://blog.csdn.net/qq_34490873/article/details/81206018

标签:python,dataframe,字符串,日期
0
投稿

猜你喜欢

  • python中通过selenium简单操作及元素定位知识点总结

    2021-07-18 15:34:37
  • go项目打包部署的完整步骤

    2024-05-09 09:46:54
  • 分享Win10 1903过TP的双机调试问题

    2023-03-09 19:02:37
  • pycharm 使用心得(九)解决No Python interpreter selected的问题

    2021-03-03 03:32:11
  • 聚族索引、非聚族索引、组合索引的含义和用途

    2010-07-02 21:51:00
  • 建立合理的索引提高SQL Server的性能

    2009-01-23 14:44:00
  • python+pytest自动化测试函数测试类测试方法的封装

    2021-12-26 21:03:14
  • js实现一个简易计算器

    2024-04-25 13:13:38
  • python的三目运算符和not in运算符使用示例

    2021-07-18 23:36:35
  • Python中模块与包有相同名字的处理方法

    2021-11-16 07:58:34
  • Python time库的时间时钟处理

    2022-12-18 23:04:23
  • Django中的用户身份验证示例详解

    2023-10-08 17:06:08
  • 深入解析Python中的list列表及其切片和迭代操作

    2023-03-24 04:20:40
  • 基于webstorm卡顿问题的2种解决方法

    2023-02-23 09:03:17
  • ASP调用数据库常见错误的解决

    2007-09-07 10:05:00
  • Python简单基础小程序的实例代码

    2021-03-29 21:17:59
  • python能做哪方面的工作

    2023-02-01 09:48:44
  • 手把手带你走进Go语言之常量解析

    2024-05-08 10:44:38
  • mysql 各种时间段查询

    2010-01-06 13:37:00
  • Python中collections.Counter()的具体使用

    2023-04-22 23:26:35
  • asp之家 网络编程 m.aspxhome.com