操作Excel通常是用如下三個(gè)擴(kuò)展體:
import xlrd
import xlwt
import openpyxl
xlrd(讀) 和 xlwt(寫)是一對(duì)。openpyxl獨(dú)立,即可讀也可寫。
正常讀都沒(méi)有問(wèn)題,只是讀有公式的cell時(shí),會(huì)出現(xiàn)如題癥狀。對(duì)此,xlrd似乎沒(méi)答案,而openpyxl開出的方子如下:
wb1 = openpyxl.load_workbook(xlsxFileWithFullPath, data_only=True)
就是加上 “data_only=True” 這個(gè)參數(shù)。
xlsxFileWithFullPath ---要操作的文件。
加上以后你會(huì)發(fā)現(xiàn),還是依然如故,或者是時(shí)可時(shí)否!
如把文件打開,再保存一遍,執(zhí)行程序,第一遍可以,第二遍就不行了!
其實(shí), 關(guān)于 data_only=True 這個(gè)參數(shù)有個(gè)重要說(shuō)明:
# data_only (bool) – controls whether cells with formula have either the formula (default) or the value stored the last time Excel read the sheet
這就解釋了上述時(shí)可時(shí)否的問(wèn)題。
這樣解決問(wèn)題的辦法就有了:用程序來(lái)完成那個(gè)保存文件的任務(wù)即可!
(1)。。。
def ReadLine(self, tip1, tip2, movingRC, fixedRC, RorC, totalCells, sheetName, xlsxFileWithFullPath):
xlsxDealer.`JustOpenAndSaveTheFile`(xlsxFileWithFullPath)
(2)。。。
def JustOpenAndSaveTheFile(self, file_name):
from win32com.client import Dispatch
xlApp = Dispatch("Excel.Application")
xlApp.Visible = False
xlBook = xlApp.Workbooks.Open(file_name)
xlBook.Save()
xlBook.Close()
問(wèn)題是解決了,速度就是有點(diǎn)慢!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。