数字转换星期几python_将日期从Excel以数字格式转换为日期格式python

I am reading data from excel and manipulating the data using python. But dates are coming as integers. How can I convert the dates back to date format?

5/15/2015 is coming as 42139.00

解决方案from datetime import datetime

excel_date = 42139

dt = datetime.fromordinal(datetime(1900, 1, 1).toordinal() + excel_date - 2)

tt = dt.timetuple()

print dt

print tt

As mentioned by J.F. Sebastian, this answer only works for any date after 1900/03/01

EDIT: (in answer to @R.K)

If your excel_date is a float number, use this code:

def floatHourToTime(fh):

h, r = divmod(fh, 1)

m, r = divmod(r*60, 1)

return (

int(h),

int(m),

int(r*60),

)

excel_date = 42139.23213

dt = datetime.fromordinal(datetime(1900, 1, 1).toordinal() + int(excel_date) - 2)

hour, minute, second = floatHourToTime(excel_date % 1)

dt = dt.replace(hour=hour, minute=minute, second=second)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值