Python结合Free Spire.XLS for Python删除Excel中的空白行列

 更新时间:2026年02月13日 08:19:04   作者:m5655bj  
在 Excel 数据处理场景中,手动删除大量空行、空列效率极低,下面我们就来看看Python如何结合Free Spire.XLS for Python实现自动化清除Excel中的空白行列吧

在 Excel 数据处理场景中,手动删除大量空行、空列效率极低,而 Python 结合 Free Spire.XLS for Python 库能实现自动化清理。相比于遍历单元格判断空值的传统方式,Free Spire.XLS 提供了 IsBlank 属性,可直接判断整行/整列是否为空,代码更简洁、执行效率更高。

环境准备

Free Spire.XLS for Python 是一款轻量级免费 Excel 处理库,无需安装 Microsoft Excel,纯 Python 环境即可操作 .xls/.xlsx 格式文件。该库可通过 pip 命令直接安装:

pip install Spire.XLS.Free

免费版仅适用于小型文档、项目

核心功能实现:删除空行空列

from spire.xls import *
from spire.xls.common import *

# 创建工作簿对象并加载文件
workbook = Workbook()
workbook.LoadFromFile("Input1.xlsx")

# 获取第一张工作表
sheet = workbook.Worksheets[0]

# 删除空白行
for i in range(sheet.Rows.Length - 1, -1, -1):
    if sheet.Rows[i].IsBlank:
        sheet.DeleteRow(i + 1)

# 删除空白列
for j in range(sheet.Columns.Length - 1, -1, -1):
    if sheet.Columns[j].IsBlank:
        sheet.DeleteColumn(j + 1)

# 保存文件
workbook.SaveToFile("Deleted.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

代码关键部分详解

代码片段功能与注意事项
sheet.Rows.Length获取工作表中总行数(含空行),作为遍历的边界值
sheet.Rows[].IsBlank核心属性:返回 True 则表示当前行所有单元格均为空
range(..., -1, -1)倒序遍历
sheet.DeleteRow()删除指定行
sheet.DeleteColumn()删除指定列
workbook.Dispose()释放工作簿占用的内存资源,大文件处理时必须添加

关键注意事项

1. IsBlank 的判断规则

IsBlank 仅将完全没有输入任何内容的单元格视为空。如果单元格包含空格字符、空字符串 “” 或公式返回的空值,IsBlank 会返回 False。若需将这些情况也视为空,可先遍历单元格清除多余空格(如 cell.Text.strip())后再处理。

2. 索引偏移陷阱

  • Rows[i] / Columns[j] 索引从 0 开始
  • DeleteRow(i) / DeleteColumn(j) 索引从 1 开始,务必在删除时 +1,否则将误删其他行/列。

3. 多工作表处理

若需清洗整个工作簿,可遍历 workbook.Worksheets 集合,对每一张表重复上述删除逻辑。

扩展功能(按需使用)

1. 批量处理文件夹下所有Excel文件

import os

# 遍历指定文件夹下所有.xlsx/.xls文件
def batch_process_excel(folder_path: str):
    for file_name in os.listdir(folder_path):
        if file_name.endswith((".xlsx", ".xls")):
            input_path = os.path.join(folder_path, file_name)
            output_path = os.path.join(folder_path, f"cleaned_{file_name}")
            delete_blank_rows_columns(input_path, output_path)

# 调用示例:处理data文件夹下所有Excel文件
batch_process_excel("data")

2. 仅删除指定列为空的行

若需实现“某列(如A列)为空则删除整行”,可替换空行判断逻辑:

# 替换原有空行删除代码
for i in range(sheet.Rows.Length - 1, -1, -1):
    # 判断A列(索引0)单元格是否为空
    if sheet.Rows[i].Cells[0].Text.strip() == "":
        sheet.DeleteRow(i + 1)

提示:Cells[0].Text 返回单元格显示的文本,strip() 可去除前后空格,避免将仅含空格的单元格视为有效数据。

总结

利用 Free Spire.XLS 提供的 IsBlank 属性和倒序删除策略,我们能够以极少的代码稳定、高效地清除 Excel 中的空白行列。该方法尤其适合以下场景:

  • 报表自动清洗流水线
  • 从异构数据源导入 Excel 前的预处理
  • 批量整理老旧 Excel 文档

配合本文提供的扩展函数,可轻松应对单文件、多文件乃至定制化条件的删除任务,大幅提升数据处理效率。

到此这篇关于Python结合Free Spire.XLS for Python删除Excel中的空白行列的文章就介绍到这了,更多相关Python删除Excel空白行列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于Tensorflow:CPU性能分析

    基于Tensorflow:CPU性能分析

    今天小编就为大家分享一篇基于Tensorflow:CPU性能分析,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • Python 读取千万级数据自动写入 MySQL 数据库

    Python 读取千万级数据自动写入 MySQL 数据库

    这篇文章主要介绍了Python 读取千万级数据自动写入 MySQL 数据库,本篇文章会给大家系统的分享千万级数据如何写入到 mysql,分为两个场景,两种方式
    2022-06-06
  • Python利用字典将两个通讯录文本合并为一个文本实例

    Python利用字典将两个通讯录文本合并为一个文本实例

    这篇文章主要介绍了Python利用字典将两个通讯录文本合并为一个文本实例,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Python中实现定时任务常见的几种方式

    Python中实现定时任务常见的几种方式

    在Python中,实现定时任务是一个常见的需求,无论是在自动化脚本、数据处理、系统监控还是其他许多应用场景中,Python提供了多种方法来实现定时任务,包括使用标准库、第三方库以及系统级别的工具,本文将详细介绍几种常见的Python定时任务实现方式
    2024-08-08
  • Python与C语言分别完成排序流程

    Python与C语言分别完成排序流程

    这篇文章主要介绍了Python与C语言分别完成排序的实例,在Python与C语言基本类型的排序中特别有用,下面我们一起进入文章学习更详细的内容吧,需要的朋友可以参考下
    2022-03-03
  • 表格梳理python内置数学模块math分析详解

    表格梳理python内置数学模块math分析详解

    这篇文章主要为大家介绍了python内置数学模块math的分析详解,文中通过表格梳理的方式以便让大家在学习过程中一目望去清晰明了,有需要的朋友可以借鉴参考下
    2021-10-10
  • Python 正则表达式匹配字符串中的http链接方法

    Python 正则表达式匹配字符串中的http链接方法

    今天小编就为大家分享一篇Python 正则表达式匹配字符串中的http链接方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • Spring http服务远程调用实现过程解析

    Spring http服务远程调用实现过程解析

    这篇文章主要介绍了Spring http服务远程调用实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • Python提取PDF内容的方法(文本、图像、线条等)

    Python提取PDF内容的方法(文本、图像、线条等)

    这篇文章主要介绍了Python提取PDF内容的方法(文本、图像、线条等),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • 利用Tensorflow构建和训练自己的CNN来做简单的验证码识别方式

    利用Tensorflow构建和训练自己的CNN来做简单的验证码识别方式

    今天小编就为大家分享一篇利用Tensorflow构建和训练自己的CNN来做简单的验证码识别方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01

最新评论