如何用openpyxl在现有的excel文件中写入数据

openpyxl文档里面有介绍把数据写入单个单元格,和逐行写入数据。但是没有介绍怎么批量把数据写入指定的行或列。想请大神指点一下。
图片描述

比如我想在第二行这里批量写入10行新的数据(格式和原表格一样),原有的数据往后面排,或者D列写入一列数据。

回答:

pandas读到dataframe里面,再改变dataframe,写入到excel中,代码最简单

回答:

楼上的方法挺好,就是安装pandas比较麻烦,新手可能不太好搞定,我倒是有个笨方法

from win32com.client import Dispatch    

import win32com.client

class 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.li\Desktop\empty_book.xlsx')

xls.inserRow('sheet1',6)

xls.save()

xls.close()

如果嫌麻烦,可以使用继承,重写类的方法。我就提供一个实现的小思路,效率比较低,也可以修改一下代码,一次插入多行,用win32com操作Excel很方便,怎么需要怎么写。

以上是 如何用openpyxl在现有的excel文件中写入数据 的全部内容, 来源链接: utcz.com/a/158189.html

回到顶部