【Python】DataFrame时间类型数据处理

这篇博客记录了在处理时间类型数据时遇到的问题,主要涉及将int类型的时间戳转换为datetime格式,并进一步分割为日期和时间两部分。通过使用`pd.to_datetime()`函数并将其转换为字符串,成功解决了从1970年开始的时间戳问题。然后利用`dt.strftime()`方法分别提取日期和时间,并将日期设置为DataFrame的Index。博主还分享了关于日期和时间格式化代码的详细说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一次处理时间类型的数据

记录一下遇到的问题及处理的代码

将int类型的数字转换成datatime格式遇到的问题

导入需要的包

import time, datetime
from datetime import datetime

一开始用pd.to_datetime()报错,时间是从1970年时间戳的时间开始的,在一篇文章中看见了方法。因为原数据是int类型,所以导致出错,解决方法是将int类型改成str类型就正确输出了。

data['Date_TIME'] =data['Date_TIME'].astype('str')
data['Date_TIME']=pd.to_datetime(data['Date_TIME'])

接下来我想将data中的日期和时间分割开

data['Date']=data['Date_TIME'].dt.strftime('%Y-%m-%d')
data['TIME']=data['Date_TIME'].dt.strftime('%H:%M:%S')

# 将年月日作为Index列进行处理
New_data =data.set_index('Date')
data.Date = pd.to_datetime(data.Date)

这段是用了另一位博主总结的部分

%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%m 月份(01-12)
%d 月内中的一天(0-31)
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%M 分钟数(00=59)
%S 秒(00-59)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Flechazo_JY

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值