Python操作Excel插入删除行
1. 前言
由于近期有任务需要,要写一个能够处理Excel的脚本,实现的功能是,在A表格上其中一列,对字符串进行分组和排序,然后根据排序好的A表格以固定格式自动填写到B表格上。
开始写脚本之前查了很多资料,最开始采用了openpyxl这个模块,用起来很顺手,使用这个对A表格其中一列进行了重新填写,但是后来发现,需要用到删除和插入空白行的操作,使用openpyxl比较困难,这个模块仅支持在表格的最后一行继续添加新行,不支持在中间插入和删除行。
在查找的过程中发现,网上流传了一些使用openpyxl进行插入删除行的操作,现整理一下。
2. 使用openpyxl
一种思路是将sheet数据转换成list,然后在list进行操作,这种方法可行,但是实际测试之后发现运行起来速度太慢了,数据1000多条,时间就已经等不起了。
# Creat insert row function group----------------------------------------------
def blankRowInsert(sheet, row_num, add_num):
myList = Sheet2List(sheet)
insertLine(myList, row_num, add_num, sheet.max_column)
List2Sheet(sheet,myList)
def Sheet2List(sheet):
# 把一个表格中的数据全部导出到一个列表
listResult = []
for i in range(1,sheet.max_row + 1):
lineData = []
for j in range(1,sheet.max_column +1):
cell = sheet.cell(row = i, column = j)
lineData.append(cell.value)
listResult.append(lineData)
return listResult
def insertLine(aList, row_num , add_num, maxColumn):
# 对列表进行添加操作操作
for _ in range(1,add_num + 1