盘点一个Pandas日期处理的问题

点击上方“Python爬虫与数据挖掘”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

弦弦掩抑声声思,似诉平生不得志。

大家好,我是皮皮。

一、前言

前几天在Python群里【爱的力量】问了一个Python日期处理的问题,这里拿出来给大家分享下。

'2022-03-25 08:00:00.000000000' 大佬们,这种格式的字符串有什么简单的方法可以转换为2022年3月25日8时吗?

这里他自己也写了一个代码,如下所示:

x = '2022-03-25 08:00:00.000000000'
x.split()[0].split('-')[0] + '年' + str(int(x.split()[0].split('-')[1])) + '月' + x.split()[0].split('-')[2] + '日' + str(int(x.split()[1].split(':')[0])) + '时'

看上去还比较复杂,希望有更简单的方法。

二、实现过程

这里【果果】给出了一个Excel版本,如下所示:

3fe8898b2fdae7b87d7029d1114468d7.png

使用Excel函数实现的,公式是:=TEXT(--LEFT(A1,19),"e年m月d日h时"),从结果来看,确实实现了需求。不过粉丝是因为要用在一个较为复杂的程序里面,这是个中间步骤,没法用excel。

想要使用Python来实现,那么该怎么来处理呢?这里是字符串格式化转时间格式,问ChatGPT应该也会有答案的。

from datetime import datetime  
  
date_str = '2022-03-25 08:00:00.000000000'  
date_time = datetime.strptime(date_str, '%Y-%m-%d %H:%M:%S.%f')  
date_time_str = date_time.strftime('%Y年%m月%d日%H时')  
  
print(date_time_str)

不过代码运行之后,会有一些小小报错,如下图所示:

8094619b0e6df8f4f3489ec688d65c1f.png

从报错来看, 是后面的0冗余了,还需要对原始字符串进行预处理下才行。

后来【F.light】也给了一个方法,代码如下图所示:

f17925e3c77581ac98a36ccbb3021609.jpeg

答案很接近了,这个代码得到的是03日08时,而粉丝需要的答案是2022年3日8时这样的结果,这里的答案还有点小瑕疵,后来【Peter】给了一个可行的代码,如下图所示:

87ebc142206f1495717f05505d3950e5.png

将代码整合到一起,就有内味了,如下图所示~

902fd559f6c740b5be33252e4a6901c9.png

三、总结

大家好,我是皮皮。这篇文章主要盘点了一个Pandas日期处理的问题,文中针对该问题,给出了多种解决方法,也给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。

3d126c5b59221f559f199f18a75248ea.png

大家在学习过程中如果有遇到问题,欢迎随时联系我解决(我的微信:pdcfighting1),应粉丝要求,我创建了一些高质量的Python付费学习交流群和付费接单群,欢迎大家加入我的Python学习交流群和接单群!

264309d55aa1d50a10778c5212a366db.png

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

67cf05619d56309b88e2e44b2cf610df.jpeg

------------------- End -------------------

往期精彩文章推荐:

d588f46c4052ba02d3e8710cab9df3b0.png

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【入群

万水千山总是情,点个【在看】行不行

/今日留言主题/

随便说一两句吧~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值