python - 如何用openpyxl在現有的excel文件中寫入數據
問題描述
openpyxl文檔里面有介紹把數據寫入單個單元格,和逐行寫入數據。但是沒有介紹怎么批量把數據寫入指定的行或列。想請大神指點一下。
比如我想在第二行這里批量寫入10行新的數據(格式和原表格一樣),原有的數據往后面排,或者D列寫入一列數據。
問題解答
回答1:pandas讀到dataframe里面,再改變dataframe,寫入到excel中,代碼最簡單
回答2:樓上的方法挺好,就是安裝pandas比較麻煩,新手可能不太好搞定,我倒是有個笨方法
from win32com.client import Dispatch import win32com.clientclass MyExcel: def __init__(self, filename=None): # 打開文件或者新建文件(如果不存在的話)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): # 關閉文件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()
如果嫌麻煩,可以使用繼承,重寫類的方法。我就提供一個實現的小思路,效率比較低,也可以修改一下代碼,一次插入多行,用win32com操作Excel很方便,怎么需要怎么寫。
相關文章:
1. javascript - angular使從elastichearch中取出的文本高亮顯示,如圖所示2. python bottle跑起來以后,定時執行的任務為什么每次都重復(多)執行一次?3. javascript - 求幫助 , ATOM不顯示界面!!!!4. 視頻文件不能播放,怎么辦?5. javascript - vue2如何獲取v-model變量名6. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題7. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處8. javascript - 為什么在谷歌控制臺 輸出1的時候,輸出的1立馬就不見了9. html5 - HTML代碼中的文字亂碼是怎么回事?10. javascript - ios返回不執行js怎么解決?
