python读取xlsx文件年月日变成数字_python excel日期数字转化datetime针对xls&xslx两种不同方式.md...

注意后缀.xlsx要用openpyxl类库处理,而之前的.xls用xlrd和xlwt进行处理即可。

针对xls读取日期为数字,如何进行转化

使用xlrd的xldate_as_tuple来处理为date格式.

案例代码:

>>> sheet2.cell(2,2).value #1990/2/22

33656.0

>>> date_value = xlrd.xldate_as_tuple(sheet2.cell_value(2,2),workbook.datemode)

>>> date_value

(1992, 2, 22, 0, 0, 0)

>>> date(*date_value[:3]).strftime('%Y/%m/%d')

'1992/02/22'

当然可以试下判断一下是否为对应时间格式

if (sheet.cell(row,col).ctype == 3):

date_value = xlrd.xldate_as_tuple(sheet.cell_value(rows,3),book.datemode)

date_tmp = date(*date_value[:3]).strftime('%Y/%m/%d')

对应ctype的得出数字含义

ctype : 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error

不过这里注意,有可能你的格式为自定义,在excel上显示也是日期的时候,这里会出错,得到的ctype为2导致错误,我的就这样,所以这个判断要不要再做考虑吧。

针对xlsx读取日期为数字,如何进行转化

此时用的类库是openpyxl,跟上面的用法又是不一样,这个问题搜索我一天了。没有现有或者说没找到现成的函数解决,只能自己搞一个

具体的思路是:

先用excel实验2018-11-02对应的日期时间戳是43406。

我再用2018-11-02减43406看看是从那一年开始计算的,所以得出结论是1899-12-30。

那最后要达成目标就只需要时间戳+1899-12-30就等于对应的当前日期

具体代码:

from datetime import date,datetime,timedelta

def get_date(dates):#定义转化日期戳的函数,dates为日期戳

delta=timedelta(days=dates)

today=datetime.strptime('1899/12/30','%Y/%m/%d')+delta#将1899-12-30转化为可以计算的时间格式并加上要转化的日期戳

return datetime.strftime(today,'%Y/%m/%d')#制定输出日期的格式

参考链接:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值