场景:在文件夹数据资料中,有多个Excel文件,每个Excel文件的格式相同,如下图所示:
现在需要删除每个Excel文件中的指定行,如下图所示,要删除Excel文件中某个Sheet的第63行:
方法一,使用win32com包:
# 导入要用到的相关包:
from win32com.client import Dispatch # 需要事先安装pywin32(win32com)
# 定义删除函数:
def row_delete1(excel_path,sht_name,row_number):
# excel_path参数为待删除的目标行所在excel文件的路径,sht_name参数为待删除的目标行所在sheet的名称
# row_number参数为待删除的目标行
# 打开工作簿
xbook = Dispatch('Excel.Application').Workbooks.Open(excel_path) # Open里面只能用绝对路径
# 访问工作簿中的目标sheet
sht = xbook.Worksheets(sht_name)
# 删除目标sheet中的指定行
sht.Rows(row_number).Delete()
# 保存打开的工作簿
xbook.Save()
# 关闭打开的工作簿
xbook.Close()
# 执行删除操作:
sheet_name = '损益明细表'
row_number = 63
for i in range(1,13):
excel_path = r'F:\数据资料\利润表-2018年{}期.xlsx'.format(i)
row_delete1(excel_path,sheet_name,row_number)
方法二,使用openpyxl包:
# 导入要用到的相关包:
import openpyxl # 需要事先安装好openpyxlb
# 定义删除函数:
def row_delete2(excel_path,sht_name,row_number):
# excel_path参数为待删除的目标Sheet所在excel文件的路径,sht_name参数为待删除的目标Sheet
## row_number参数为待删除的目标行
# 载入工作簿
wb = openpyxl.load_workbook(excel_path)
# 删除目标行
ws = wb[sht_name]
ws.delete_rows(row_number)
# 保存已做删除处理的工作簿
wb.save(excel_path)
# 执行删除操作:
sheet_name = '损益明细表'
row_number = 63
for i in range(1,13):
excel_path = r'F:\数据资料\利润表-2018年{}期.xlsx'.format(i)
row_delete2(excel_path,sheet_name,row_number)
与方法二不同,方法一需要打开和关闭Excel工作簿,这也导致方法二的速度较慢。
场景:在文件夹数据资料中,有多个Excel文件,每个Excel文件的格式相同,且每个Excel文件中都有一个名称为法人利润表的Sheet,现在需要将所有Excel文件中名为法人利润表的Sheet都删除。
代码:
# 导入要用到的相关包:
import openpyxl
# 定义删除函数:
def sheet_delete(excel_path,sht_name):
# excel_path参数为待删除的目标Sheet所在excel文件的路径,sht_name参数为待删除的目标Sheet
# 载入工作簿
wb = openpyxl.load_workbook(excel_path)
# 删除目标Sheet
ws = wb[sht_name]
wb.remove(ws)
# 保存已做删除处理的工作簿
wb.save(excel_path)
# 执行删除操作:
sheet_name = '法人利润表'
for i in range(1,13):
excel_path = r'F:\数据资料\利润表-2018年{}期.xlsx'.format(i)
sheet_delete(excel_path,sheet_name)
上述需要删除的指定行和指定Sheet所在的Excel工作簿都是在同一个文件夹下的,但在实际情况中,这些Excel工作簿可能会分布在不同的文件夹下,如下图所示,在TEST文件夹下,有六个用于存放Excel工作簿的文件夹(TEST文件夹下只有这六个文件夹):
这个时候该怎么办呢?其实,我们可以通过OS模块获取Excel工作簿所在文件夹的文件夹名称,然后依次遍历不同文件夹下的所有Excel工作簿。以删除指定行为例(删除指定Sheet同理),代码如下:
# 导入需要用到的相关包:
import os
import openpyxl
# 定义删除函数:
def row_delete3(excel_path,sht_name,row_number):
# excel_path参数为待删除的目标Sheet所在excel文件的路径,sht_name参数为待删除的目标Sheet
## row_number参数为待删除的目标行
# 载入工作簿
wb = openpyxl.load_workbook(excel_path)
# 删除目标行
ws = wb[sht_name]
ws.delete_rows(row_number)
# 保存已做删除处理的工作簿
wb.save(excel_path)
path = r'F:\数据资料\TEST' # 用于存放Excel工作簿的不同文件夹的路径
files = os.listdir(path) # 获取TEST文件夹下所有文件夹的文件夹名
# 执行删除操作:
sheet_name = '损益明细表'
row_number = 63
for file in files:
for i in range(1,13):
excel_path = r'F:\数据资料\TEST\{}\利润表-2018年{}期.xlsx'.format(file,i)
row_delete3(excel_path,sheet_name,row_number)
openpyxl除了删除指定行和指定Sheet外,还可以删除指定列,具体可以参考:https://openpyxl.readthedocs.io/en/stable/editing_worksheets.html
其他参考:
https://blog.csdn.net/qq_36928258/article/details/82862950
https://openpyxl.readthedocs.io/en/stable/api/openpyxl.worksheet.worksheet.html
https://openpyxl.readthedocs.io/en/stable/api/openpyxl.workbook.workbook.html