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. atom编译器 如何格式化前端代码文件?2. javascript - webpack热加载配置不生效3. css3 - 我的css用less写的,eclipse的jsp文件要修改css很麻烦,怎么解决?4. android - 新建项目卡在Gradle:Resolvedependencies’:app:_debugCompile’5. angular.js - ng-repeat的数据排序,我用了orderBy: d.supportNum为什么失效?6. python - Pycharm调试代码进行列表遍历时,如何直接赋值指定元素7. javascript - 关于在angularjs的select中遇到的问题!!8. android - NavigationView 的侧滑菜单中如何保存新增项(通过程序添加)9. android - 使用listview加载不同item,数据填充错误。10. python - 基于scrapy-redis的分布式爬虫运行的时候不能正常运行 遇到的问题如下截图所示