Python批量处理Excel文件之删除操作

批量删除多个Excel文件中的同一指定行

场景:在文件夹数据资料中,有多个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文件中的同一指定Sheet

场景:在文件夹数据资料中,有多个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

 

  • 6
    点赞
  • 100
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
要使用Python批量处理Excel文件,可以按照以下步骤进行操作: 1. 首先,导入所需的库,如pandas和os: ```python import pandas as pd import os ``` 2. 获取指定文件夹下的所有文件名: ```python name_list = os.listdir('文件夹路径') ``` 3. 使用循环遍历每个文件,并读取Excel文件: ```python for file_name in name_list: df = pd.read_excel('文件夹路径/' + file_name) # 在这里可以对读取的Excel文件进行相应的操作 ``` 4. 如果需要对读取的文件进行数据操作,可以在读取代码之后添加相应的操作代码。例如,删除重复值: ```python for file_name in name_list: df = pd.read_excel('文件夹路径/' + file_name) df = df.drop_duplicates() # 在这里可以进行其他的数据操作 ``` 5. 如果需要将多个Excel文件合并成一个文件,可以使用concat函数进行纵向拼接: ```python df_combined = pd.DataFrame() # 创建一个空的DataFrame用于存储合并后的数据 for file_name in name_list: df = pd.read_excel('文件夹路径/' + file_name) df_combined = pd.concat(\[df_combined, df\]) ``` 请注意,以上代码仅为示例,具体的文件路径和操作代码需要根据实际情况进行修改。 #### 引用[.reference_title] - *1* *2* *3* [利用PythonExcel文件进行批量操作](https://blog.csdn.net/junhongzhang/article/details/121436949)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值