[python3]Excel解析库-xlutils

`xlutils` 是一组用于处理 Excel 文件的 Python 库,它实际上是 `xlrd` 和 `xlwt` 的扩展,提供了额外的功能来操作 Excel 文件。`xlutils` 主要由三个部分组成:`xlutils.copy`、`xlutils.filter` 和 `xlutils.view`,它们分别用于复制和修改现有 Excel 文件、过滤数据以及查看 Excel 文件的内容。

安装

要使用 `xlutils`,首先需要安装它。可以通过 pip 来安装最新版本:

复制代码
```bash
pip3 install xlutils
```

由于 `xlutils` 依赖于 `xlrd` 和 `xlwt`,确保你也安装了这两个库(注意,对于 `.xls` 文件的支持,`xlrd` 版本应低于2.0.0,因为从2.0.0开始,`xlrd` 不再支持 `.xls` 文件):

复制代码
```bash
pip install xlrd<2.0.0 xlwt
```

基本用法

复制代码
#### 使用 `xlutils.copy` 修改现有文件

`xlutils.copy` 允许你读取一个现有的 `.xls` 文件,并创建一个可编辑的副本。然后你可以对这个副本进行修改,最后保存为新的文件或覆盖原文件。

```python
import xlrd
from xlutils.copy import copy

# 打开现有的工作簿
rb = xlrd.open_workbook('example.xls', formatting_info=True)

# 创建副本
wb = copy(rb)

# 获取第一个工作表
sheet = wb.get_sheet(0)

# 修改单元格内容
sheet.write(0, 0, 'Updated Value')

# 保存更改到新文件
wb.save('updated_example.xls')
```

#### 使用 `xlutils.filter` 过滤数据

`xlutils.filter` 提供了一种机制,可以让你通过定义过滤器来自定义处理 Excel 文件的方式。例如,你可以编写一个过滤器来移除空白行或应用特定的格式化规则。

```python
from xlutils.filter import process, XLRDReader, XLWTWriter
from xlrd import open_workbook
from xlwt import Workbook

def remove_blank_rows(record):
    if record.name == 'row':
        if not any(cell.value for cell in record.cells):
            return False
    return True

# 打开现有的工作簿
book = open_workbook('example.xls')

# 设置输入输出处理器
process(
    XLRDReader(book, 'example.xls'),
    XLWTWriter(),
    sheet_records=[remove_blank_rows]  # 应用过滤器
)

# 保存结果到新文件
writer.save('filtered_example.xls')
```

#### 使用 `xlutils.view` 查看文件内容

`xlutils.view` 提供了一些简单的工具来查看 Excel 文件的内容,主要用于调试目的。例如,它可以将 Excel 表格转换为 HTML 格式以便在浏览器中查看。

```python
from xlutils.view import view

# 打开现有的工作簿并查看其内容
view('example.xls')
```

### 注意事项

- `xlutils` 只适用于 `.xls` 文件格式。如果你需要处理 `.xlsx` 文件,请考虑使用其他库如 `openpyxl` 或 `XlsxWriter`。
- 由于 `xlutils` 依赖于 `xlrd` 和 `xlwt`,而这些库已经不再积极维护,因此对于现代项目来说,可能更推荐使用更新的库来进行 Excel 文件的操作。
- 在处理较大文件时,`xlutils` 可能会遇到性能问题,因为它需要将整个文件加载到内存中进行处理。

### 示例:完整代码示例

以下是一个完整的例子,演示了如何使用 `xlutils` 修改现有的 `.xls` 文件并在其中添加新的数据:

```python
import xlrd
from xlutils.copy import copy

def update_excel_file(input_file, output_file):
    # 打开现有的工作簿
    rb = xlrd.open_workbook(input_file, formatting_info=True)

    # 创建副本
    wb = copy(rb)

    # 获取第一个工作表
    sheet = wb.get_sheet(0)

    # 添加新数据
    new_data = [
        ['New Data 1', 'Value 1'],
        ['New Data 2', 'Value 2']
    ]
    start_row = sheet.nrows  # 获取当前行数以确定插入位置

    for row_index, row_data in enumerate(new_data, start=start_row):
        for col_index, value in enumerate(row_data):
            sheet.write(row_index, col_index, value)

    # 保存更改到新文件
    wb.save(output_file)

if __name__ == "__main__":
    input_file = 'example.xls'
    output_file = 'updated_example.xls'
    update_excel_file(input_file, output_file)
```

总结

`xlutils` 是一个有用的工具集,特别适合那些需要频繁读取和修改 `.xls` 文件的项目。然而,考虑到 `xlrd` 和 `xlwt` 的局限性及其缺乏活跃维护的状态,在选择工具时应该权衡项目的长期需求和技术栈的选择。

相关推荐
2301_7869643620 分钟前
EXCEL Python 实现绘制柱状线型组合图和树状图(包含数据透视表)
python·microsoft·excel
玩电脑的辣条哥23 分钟前
怎么在excel单元格1-5行中在原来内容前面加上固定一个字?
excel
skd899942 分钟前
小蜗牛拨号助手用户使用手册
python
「QT(C++)开发工程师」1 小时前
STM32 | FreeRTOS 递归信号量
python·stm32·嵌入式硬件
海绵宝宝贾克斯儿1 小时前
C++中如何实现一个单例模式?
开发语言·c++·单例模式
史迪仔01121 小时前
[python] Python单例模式:__new__与线程安全解析
开发语言·python·单例模式
胡耀超1 小时前
18.自动化生成知识图谱的多维度质量评估方法论
人工智能·python·自动化·知识图谱·数据科学·逻辑学·质量评估
isyangli_blog1 小时前
(1-4)Java Object类、Final、注解、设计模式、抽象类、接口、内部类
java·开发语言
三块钱07941 小时前
【原创】基于视觉大模型gemma-3-4b实现短视频自动识别内容并生成解说文案
开发语言·python·音视频
易只轻松熊1 小时前
C++(20): 文件输入输出库 —— <fstream>
开发语言·c++·算法