浮点数转日期

在实际工作中发现,在导入excel时,读取cell时,经常有人将日期变成了一个double类型,该double类型的整数部分表示1900年以来的天数,小数表示当天的描述,因此,在Python中,就可以用timedelta进行加减,计算出该double类型代表的正真的日期:

方法1:利用xlrd中的xldate_as_datetime(xldate, datemode)函数进行转换,该函数两个参数,第一个参数就是double,第二个参数:0表示从1900年开始计算,1表示从1904年开始计算。如xldate_as_datetime(45020.4811226852, 0)转换出来是2023-04-04 11:32:49

方法2:直接利用timedelta计算,这里要注意,从1900开始计算的天数时,其基准是1899年12月30日0时,而不是1899年12月31日0时:

date1900 = datetime(1899,12,30,0,0,0)

date = date1900+timedelta(days=int(45020.4811226852))+timedelta(seconds=(45020.4811226852-int(45020.4811226852))*3600*24)

以上为python中的实现方式,原理已经清楚,其他语言可以根据原理自行实现。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值