楼上的方法挺好,就是安装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很方便,怎么需要怎么写。