datetime.datetime、datetime.date、datetime.time的相互转换

在一次课程设计中,需要将df数组中“time”字段小于某个阈值的数据筛选出来,日期格式为时分秒,即“%H:%M:%S”。

然后使用

df['time']<'02:00:00'

 出现报错,

'<' not supported between instances of 'datetime.time' and 'str'

意思就是说datetime.time与字符串不能比较,这里很明显“02:00:00”是字符串,所以我们需要将字符串转化为时间格式,使用下面的代码

from datetime import datetime #导入datetime
threshold =datetime.strptime('07:00:00','%H:%M:%S')#把字符串转化为时间格式
#这一块不知道的,建议去了解一下strptime与strftime
df['time']<threshold 

欸嘿,以为没错了,这下又报错:

 '<' not supported between instances of 'datetime.time' and 'datetime.datetime'

好了,这又是什么问题呢,datetime.time与datetime.datetime不能比较,因为这里定义的阈值是datetime.datetime格式,而我们的df['time']是datetime.time。如何解决这个问题呢,将他们的type统一,如果你想将df['time']改为datetime.datetime你会发现显示Series不能转化,会比较麻烦,这里我们将阈值threshold转化为datetime.time格式,这样就不会报错了。

from datetime import datetime #导入datetime
threshold =datetime.time(datetime.strptime('07:00:00','%H:%M:%S'))#把字符串转化为时间格式
#这一块不知道的,建议去了解一下strptime与strftime
df['time']<threshold 

如果你遇到的是datetime.date,道理也是相同的。

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果你想将datetime.date对象转换datetime.datetime对象,你可以使用datetime.datetime.combine()方法。这个方法将date对象和一个time对象结合起来创建一个新的datetime对象。你可以传入date对象作为第一个参数,并使用datetime.time.min作为第二个参数,这样可以创建一个时间为午夜的datetime对象。例如,使用datetime.datetime.combine(dateobject, datetime.time.min)可以将dateobject转换datetime.datetime对象。 另一种方法是使用datetime.date.today()来获取当前日期,然后将其与一个空的时间对象进行结合,即datetime.datetime.combine(dateobject, datetime.time())。这将创建一个当前日期且时间为午夜的datetime.datetime对象。 需要注意的是,根据你的引用,你提到的日期时间.js扩展和Javascript Date对象是与Pythondatetime模块不同的概念。因此,这里提供的方法适用于Python中的datetime模块。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [odoo python datetime.datedatetime.datetime](https://blog.csdn.net/fqfq123456/article/details/124502493)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [datetime.js:扩展 JavaScript 日期对象](https://download.csdn.net/download/weixin_42139252/19643293)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值