当前位置: 首页 > news >正文

如何使用 Python 删除 Excel 中的行、列和单元格 – 详解

目录

开发环境准备

使用 Python 删除 Excel 表格中的行

删除特定行

删除空白行

删除含指定数据的行

使用 Python 删除 Excel 表格中的列

删除特定列

删除空白列

删除含指定数据的列

使用 Python 删除 Excel 中的单元格并自动移动剩余内容

删除特定单元格

删除空白单元格

删除含指定数据的单元格


Python 删除Excel表格中的行、列和单元格

在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作。然而,当面对大量 Excel 文件或结构复杂的数据表格时,手动处理这些任务不仅效率低下,还容易因操作失误造成数据错误。

使用 Python脚本,可以实现对 Excel 表格的高效自动化处理。无论是删除指定的行或列、批量清除空白行和空白列,还是根据关键字筛选并删除包含特定数据的单元格,这些操作都可以通过脚本一次性完成,大幅提升工作效率和准确性。

本文将详细介绍如何使用 Python 删除 Excel 中的行、列和单元格,内容涵盖以下几个方面:

  • 开发环境准备
  • 使用 Python 删除 Excel 表格中的行
    • 删除特定行
    • 删除空白行
    • 删除含指定数据的行
  • 使用 Python 删除 Excel 表格中的列
    • 删除特定列
    • 删除空白列
    • 删除含指定数据的列
  • 使用 Python 删除 Excel 中的单元格并自动移动剩余内容
    • 删除特定单元格
    • 删除空白单元格
    • 删除含指定数据的单元格

开发环境准备

在操作 Excel 文件之前,首先需要准备好 Python 开发环境,并引入相应的库。本文将使用第三方库 Spire.XLS for Python,它支持读取、修改、写入以及转换 Excel 文件,且不依赖微软Office或其他第三方软件。

安装 Spire.XLS

Spire.XLS 提供了两个版本,可以根据需求选择合适的版本:

  • 社区版:免费使用,但每个 .xls 文件限制为 200 行和 5 个工作表(.xlsx 文件没有此限制)。安装命令:
    pip install spire.xls.free
  • 商业版:功能完备,但会添加水印。可以在 [这里] 申请免费的测试许可证。
    安装命令:
    pip install spire.xls

安装完成后,即可在Python应用程序中调用该库的API。

使用 Python 删除 Excel 表格中的行

删除特定行

如果你已知需要删除的行号,可以使用Worksheet.DeleteRow(rowIndex: int, rowCount: int) 方法,通过指定起始行号和删除行数,直接移除一行或多行数据。这种方式适用于结构固定或需要批量删除指定位置行的 Excel 表格。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 调用 DeleteRow() 方法删除指定行。
  • 保存修改后的文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 从第 5 行开始删除 2 行
worksheet.DeleteRow(5, 2)# 保存结果文件
workbook.SaveToFile("删除特定行.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

删除空白行

在处理 Excel 表格时,空白行会影响数据的完整性和可读性。使用 Worksheet.Rows[index].IsBlank 属性,可以轻松判断某一行是否为空。若返回值为 True,则说明该行为空白行,可使用 DeleteRow() 方法将其删除。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 倒序遍历所有行,使用 IsBlank 属性判断其是否为空。
  • 对空白行调用 DeleteRow() 方法进行删除。
  • 保存修改后的 Excel 文件。

实现代码:

from spire.xls import *
from spire.xls.common import *# 创建 Workbook 实例
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")
# 获取第一个工作表
sheet = workbook.Worksheets[0]# 删除空白行(倒序遍历避免索引错误)
for i in range(sheet.Rows.Length - 1, -1, -1):if sheet.Rows[i].IsBlank:sheet.DeleteRow(i + 1)# 保存结果文件
workbook.SaveToFile("删除空白行", ExcelVersion.Version2013)
workbook.Dispose()

删除含指定数据的行

当需要删除某些包含特定关键词(如“已取消”、“无效”)的行时,可通过Worksheet.FindAll()方法查找关键词所在的单元格并获取其所在行,再使用DeleteRow()方法删除这些行。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 使用 FindAll() 方法查找包含指定内容的所有单元格。
  • 提取这些单元格所在的行索引,并去重。
  • 倒序遍历行索引并使用DeleteRow()方法逐行删除。
  • 保存处理后的文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 查找包含特定值的单元格
ranges = worksheet.FindAll("已取消", FindType.Text, ExcelFindOptions.MatchEntireCellContent)
# 存储行索引
row_indexes = []# 遍历查找到的单元格
for range in ranges:row_index = range.Rowif row_index not in row_indexes:row_indexes.append(row_index)# 倒序排列行索引
row_indexes.sort(reverse=True)# 逐行删除
for row_index in row_indexes:worksheet.DeleteRow(row_index)# 保存结果文件
workbook.SaveToFile("删除含特定数据的行.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

使用 Python 删除 Excel 表格中的列

删除特定列

若已明确某些列不再需要,可通过使用Worksheet.DeleteColumn(columnIndex: int, columnCount: int) 方法,删除一列或多列。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 使用 DeleteColumn() 方法,从工作表中删除指定列。
  • 保存修改后的文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 从第 3 列开始删除 2 列
worksheet.DeleteColumn(3, 2)# 保存结果文件
workbook.SaveToFile("删除特定列.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

删除空白列

空白列在 Excel 表格中同样会造成数据干扰。使用 Worksheet.Columns[index].IsBlank 属性可以检测列是否为空,若返回值为 True,即可调用 DeleteColumn() 方法删除该列。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 倒序遍历所有列,使用IsBlank属性判断其是否为空。
  • 若为空,则调用 DeleteColumn() 方法进行删除。
  • 保存修改后的文件。

实现代码:

from spire.xls import *
from spire.xls.common import *# 创建 Workbook 实例
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")
# 获取第一个工作表
sheet = workbook.Worksheets[0]# 删除空白列(倒序遍历避免索引混乱)
for i in range(sheet.Columns.Length - 1, -1, -1):if sheet.Columns[i].IsBlank:sheet.DeleteColumn(i + 1)# 保存结果文件
workbook.SaveToFile("删除空白列.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

删除含指定数据的列

如果你需要删除包含某个特定值的整列数据,比如含有“测试”的列,可以使用Worksheet.FindAll()方法查找数据,获取其所在单元格,获取该单元格所在列,再调用 DeleteColumn() 方法删除对应列。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 使用 FindAll() 方法查找包含指定文本的单元格;
  • 提取这些单元格所在的列索引,并去重;
  • 倒序遍历列索引并使用DeleteColumn()方法逐列删除;
  • 保存文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 查找包含指定值的单元格
ranges = worksheet.FindAll("测试", FindType.Text, ExcelFindOptions.MatchEntireCellContent)
# 存储列索引
col_indexes = []# 遍历查找到的单元格
for range in ranges:col_index = range.Columnif col_index not in col_indexes:col_indexes.append(col_index)# 倒序排列列索引
col_indexes.sort(reverse=True)# 逐列删除
for col_index in col_indexes:worksheet.DeleteColumn(col_index)# 保存结果文件
workbook.SaveToFile("删除含指定数据的列.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

使用 Python 删除 Excel 中的单元格并自动移动剩余内容

删除特定单元格

相较于整行整列的删除,删除单元格更常用于局部调整。例如在数据导入后,可能存在个别无效单元格需要清除,并将其他数据自动移位填充。

使用Worksheet.DeleteRange()方法,可以轻松移除不需要的单元格或单元格范围,并指定剩余内容的移动方向,例如DeleteOption.MoveLeft,表示将剩余单元格内容向左移。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 获取目标区域的单元格范围。
  • 调用 DeleteRange() 方法删除该单元格范围并设置剩余内容的移动方向;
  • 保存修改后的文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 通过指定起始行、起始列、结束行和结束列确定要删除的单元格范围(也可以使用范围名称如 "A2:B3")
range_to_delete = worksheet.Range[2, 1, 3, 2]# 删除该区域,并将其右侧单元格左移
worksheet.DeleteRange(range_to_delete, DeleteOption.MoveLeft)# 保存结果文件
workbook.SaveToFile("删除特定单元格.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

删除空白单元格

空白单元格可能导致数据排列不整齐或计算错误。可以使用 Worksheet.Cells[index].IsBlank 属性逐个检测单元格是否为空,然后使用 DeleteRange() 删除它并设置剩余数据的移动方向。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 遍历工作表中的所有单元格。
  • 使用IsBlank属性判断其是否为空。
  • 若为空则使用 DeleteRange() 删除它并设置其右侧剩余数据的移动方向。
  • 保存结果文件。

示例代码:

from spire.xls import *
from spire.xls.common import *# 创建 Workbook 实例
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")
# 获取第一个工作表
sheet = workbook.Worksheets[0]# 删除空白单元格(倒序遍历避免索引问题)
for i in range(sheet.Cells.Length - 1, -1, -1):if sheet.Cells[i].IsBlank:sheet.DeleteRange(sheet.Cells[i], DeleteOption.MoveLeft)# 保存结果文件
workbook.SaveToFile("删除空白单元格.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

删除含指定数据的单元格

如果需要删除表格中包含特定内容的单元格,可以使用Workbook.FindAll()方法查找这些单元格,然后使用 DeleteRange() 删除这些单元格并设置剩余数据的移动方向。

实现步骤:

  • 创建 Workbook 对象并加载 Excel 文件。
  • 获取目标工作表。
  • 使用 Workbook.FindAll() 方法查找包含指定内容的单元格。
  • 遍历这些单元格,调用 DeleteRange() 删除它们并移动剩余内容。
  • 保存修改后的文件。

实现代码:

from spire.xls.common import *
from spire.xls import *# 创建 Workbook 对象
workbook = Workbook()
# 加载 Excel 文件
workbook.LoadFromFile("测试.xlsx")# 获取第一个工作表
worksheet = workbook.Worksheets[0]# 查找包含指定值的所有单元格
ranges = worksheet.FindAll("测试", FindType.Text, ExcelFindOptions.MatchEntireCellContent)# 逐个删除这些单元格,并将右侧单元格左移
for range in ranges:worksheet.DeleteRange(range, DeleteOption.MoveLeft)# 保存结果文件
workbook.SaveToFile("删除含特定数据的单元格.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

以上就是使用 Python 和 Spire.XLS 删除 Excel 文件中行、列和单元格的完整方法。如果你觉得这篇文章对你有所帮助,欢迎点赞、收藏或分享给有需要的朋友!!

http://www.xdnf.cn/news/1101943.html

相关文章:

  • 《探索电脑麦克风声音采集多窗口实时可视化技术》
  • xFile:高性能虚拟分布式加密存储系统——Go
  • 上位机知识篇---Git符号链接
  • python的类型注解讲解
  • 云、实时、时序数据库混合应用:医疗数据管理的革新与展望(中)
  • 电力自动化的通信中枢,为何工业交换机越来越重要?
  • NLP_知识图谱_大模型——个人学习记录
  • CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
  • LVS-NAT模式配置
  • Java语言基础
  • Windos服务器升级MySQL版本
  • 从Excel到PDF一步到位的台签打印解决方案
  • 5G标准学习笔记14 - CSI--RS概述
  • 《磁力下载工具实测:资源搜索+高速下载一站式解决方案》
  • P1204 [USACO1.2] 挤牛奶Milking Cows
  • 【Linux】GDB/CGDB 调试器学习笔记
  • 实现在线预览pdf功能,后台下载PDF
  • 【web应用】若依框架中,使用Echarts导出报表为PDF文件
  • SSL与HTTP概述
  • 【网络编程】KCP——可靠的 UDP 传输协议——的知识汇总
  • 华为VS格行VS中兴VS波导随身WIFI6怎么选?流量卡OR随身WIFI,长期使用到底谁更香?
  • leetcode 3169. 无需开会的工作日 中等
  • day02-数组part02
  • 【LeetCode 热题 100】146. LRU 缓存——哈希表+双向链表
  • 十年架构心路:从单机到云原生的分布式系统演进史
  • OcsNG基于debian一键部署脚本
  • 老系统改造增加初始化,自动化数据源配置(tomcat+jsp+springmvc)
  • JVM--监控和故障处理工具
  • 正义的算法迷宫—人工智能重构司法体系的技术悖论与文明试炼
  • 区块链应用场景深度解读:从金融革命到社会治理的全方位革新