在实际工作中发现,在导入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中的实现方式,原理已经清楚,其他语言可以根据原理自行实现。