有没有办法用 Python openpyxl 从 excel 读取持续时间类型字段?

Is there a way to read duration type field from excel with Python openpyxl?

我正在尝试从 Excel 文件中读取持续时间字段,但我得到的不是 timedelta 类型,而是 datetime 类型。因此,当持续时间值超过 24 小时时,python openpyxl 无法正确读取该字段。 Python openpyxl 是否有正确的读取持续时间字段的方法?

import openpyxl

workbook = openpyxl.load_workbook('./files/file.xlsx')
worksheet = workbook.active

cell = worksheet.cell(row=2, column=9)
print(cell.value)

excel 文件中的单元格(行=2,列=9)值为 38:12:40,但打印输出:

1900-01-01 14:12:40

excel 文件中的单元格格式代码 - [HH]:MM:SS

我认为这个解决方案适合你,也许你需要调整格式但类型是 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 年开始的格式