Python从Excel表格中读取日期格式遇到的问题及对策

在从Excel表中读取基金交易明细过程中,交易日期的读取一直卡壳。Excel表中的日期是格式良好的2019/10/11,但是读取到了Python中就成了43749.0

这一个数字怎么转换成正确的日期格式呢?

import xlrd

rdBook=xlrd.open_workbook('日期.xls')
rdSheet=rdBook.sheet_by_name('Sheet1')

print(rdSheet.cell_value(0,0))

查了网上资料,Excel的日期产生机制是以一个特定日为基准(在单元格中输入数字1,然后设置单元格式为日期,就会得到1900/01/01这个日期),计算当前单元格日期与基准日的天数,然后展现为日期。43749就是这个天数。

那就考虑用datetime库,若以1900-01-01为基准日期上加43749天,竟然是2019-10-13,也就是多了2天(这一原因还没看明白),因此调整一下基础日期为1899-12-30,输出就是正确的日期咯。代码如下:

import xlrd
import datetime

rdBook=xlrd.open_workbook('日期.xls')
rdSheet=rdBook.sheet_by_name('Sheet1')
# 以下会输出一个数字
print(rdSheet.cell_value(0,0))

# 正确转化Excel日期
def ConvertDate(xlDate):
    # 这里delta是两个日期间隔天数的意思,取值就是Excel来的数字
    delta=datetime.timedelta(days=xlDate)
    # 基础日期就是1899-12-30,将间隔天数加到这个日期上,得到正确的日期戳
    today=datetime.datetime.strptime('1899-12-30','%Y-%m-%d')+delta
    # 格式化输出正确的日期
    return datetime.datetime.strftime(today,'%Y-%m-%d')
# 以下会正确输出日期
print(ConvertDate(rdSheet.cell_value(0,0)))

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

RockyCoder

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

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

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

打赏作者

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

抵扣说明:

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

余额充值