我正在尝试从 Excel 文件中读取持续时间字段,但我得到的是 datetime 类型,而不是 timedelta 类型。因此,当持续时间值超过 24 小时时,python openpyxl 会错误地读取该字段。是否有使用 Python openpyxl 读取持续时间字段的正确方法?import openpyxlworkbook = openpyxl.load_workbook('./files/file.xlsx')worksheet = workbook.activecell = worksheet.cell(row=2, column=9)print(cell.value)excel文件中的单元格(行=2,列=9)值为38:12:40,但打印输出:1900-01-01 14:12:40Excel 文件中的单元格格式代码 - [HH]:MM:SS
1 回答

慕田峪9158850
TA贡献1794条经验 获得超7个赞
我认为这个解决方案对你有用,也许你需要调整格式但类型是 timedelta
cell = worksheet.cell(row=1, column=1)
print(cell.value) #1900-01-01 14:12:40
s = cell.value-datetime.datetime(1899,12,30)
print(s) #2 days, 14:12:40
print(type(s)) #<class 'datetime.timedelta'>
问题是 Excel 有一个自定义类型,当您输入该格式时,它会从 1900 年开始将其转换为该格式
添加回答
举报
0/150
提交
取消