python - 如何用openpyxl在現(xiàn)有的excel文件中寫(xiě)入數(shù)據(jù)
問(wèn)題描述
openpyxl文檔里面有介紹把數(shù)據(jù)寫(xiě)入單個(gè)單元格,和逐行寫(xiě)入數(shù)據(jù)。但是沒(méi)有介紹怎么批量把數(shù)據(jù)寫(xiě)入指定的行或列。想請(qǐng)大神指點(diǎn)一下。
比如我想在第二行這里批量寫(xiě)入10行新的數(shù)據(jù)(格式和原表格一樣),原有的數(shù)據(jù)往后面排,或者D列寫(xiě)入一列數(shù)據(jù)。
問(wèn)題解答
回答1:pandas讀到dataframe里面,再改變dataframe,寫(xiě)入到excel中,代碼最簡(jiǎn)單
回答2:樓上的方法挺好,就是安裝pandas比較麻煩,新手可能不太好搞定,我倒是有個(gè)笨方法
from win32com.client import Dispatch import win32com.clientclass MyExcel: def __init__(self, filename=None): # 打開(kāi)文件或者新建文件(如果不存在的話)self.xlApp = win32com.client.Dispatch(’Excel.Application’)if filename: self.filename = filename self.xlBook = self.xlApp.Workbooks.Open(filename)else: self.xlBook = self.xlApp.Workbooks.Add() self.filename = ’’ def save(self, newfilename=None): # 保存文件if newfilename: self.filename = newfilename self.xlBook.SaveAs(newfilename)else: self.xlBook.Save() def close(self): # 關(guān)閉文件self.xlBook.Close(SaveChanges=0)del self.xlApp def inserRow(self, sheetname, row):sht = self.xlBook.Worksheets(sheetname)sht.Rows(row).Insert()if __name__ == '__main__': xls = MyExcel(r’d:jason.liDesktopempty_book.xlsx’) xls.inserRow(’sheet1’,6) xls.save() xls.close()
如果嫌麻煩,可以使用繼承,重寫(xiě)類的方法。我就提供一個(gè)實(shí)現(xiàn)的小思路,效率比較低,也可以修改一下代碼,一次插入多行,用win32com操作Excel很方便,怎么需要怎么寫(xiě)。
相關(guān)文章:
1. javascript - 微信h5發(fā)送圖文信息,部分設(shè)備點(diǎn)擊“發(fā)送”按鈕時(shí)沒(méi)反應(yīng),問(wèn)題較難重現(xiàn),如何能找到可能存在問(wèn)題的點(diǎn)?2. objective-c - 做一個(gè)百度地圖定位的demo,結(jié)果出錯(cuò)好多。3. 微信小程序session無(wú)法緩存的問(wèn)題4. java-web - Java WEB:什么樣的jar包必須放到WEB-INF下?有些包放外面tomcat就起不來(lái)5. javascript - 關(guān)于微信授權(quán)的問(wèn)題。6. java - 輸出4個(gè)不相等整數(shù)之間所有任意三個(gè)整數(shù)的乘積7. css - 如何使用 vue transition 實(shí)現(xiàn) ios 按鈕一樣的平滑切換效果8. 如何使用Java1.8編譯1.6JVM可運(yùn)行的class文件9. angular.js - 公眾號(hào)H5頁(yè)面 angularjs 怎么動(dòng)態(tài)修改title值(微信6.5.5,動(dòng)態(tài)修改不行 6.5.7闊以)10. node.js - 如何在服務(wù)器部署vuejs項(xiàng)目?
