胡說(shuō)叔叔
2022-05-24 17:10:31
我正在嘗試從 Excel 文件中讀取持續(xù)時(shí)間字段,但我得到的是 datetime 類(lèi)型,而不是 timedelta 類(lèi)型。因此,當(dāng)持續(xù)時(shí)間值超過(guò) 24 小時(shí)時(shí),python openpyxl 會(huì)錯(cuò)誤地讀取該字段。是否有使用 Python openpyxl 讀取持續(xù)時(shí)間字段的正確方法?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貢獻(xiàn)1794條經(jīng)驗(yàn) 獲得超8個(gè)贊
我認(rèn)為這個(gè)解決方案對(duì)你有用,也許你需要調(diào)整格式但類(lèi)型是 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'>
問(wèn)題是 Excel 有一個(gè)自定義類(lèi)型,當(dāng)您輸入該格式時(shí),它會(huì)從 1900 年開(kāi)始將其轉(zhuǎn)換為該格式
添加回答
舉報(bào)
0/150
提交
取消