国产化Excel开发组件Spire.XLS教程:Python将列表导出为CSV文件(含一维/二维/字典列表)

在数据处理与交换中,CSV(逗号分隔值)格式因简洁通用,成为跨应用、跨数据库的数据交换首选。对于 Python 开发者而言,将 Python 列表转换为 CSV 格式是高频需求------无论是导出应用数据、生成报表,还是准备分析数据集,都离不开这一操作。

Spire.XLS for Python 凭借直观可靠的方法简化了这一过程,无需依赖 Microsoft Excel,即可轻松将各类列表导出到 CSV 文件。本文将分步骤详解如何利用该工具实现转换,覆盖从简单一维列表到复杂字典列表的全场景。

Spire.XLS for Python试用下载

Spire.XLS for Python 快速入门

为什么选择 Spire.XLS?

Python内置的 csv 模块可满足基础需求,但 **Spire.XLS**提供了更强大的功能:

  • 无缝兼容多种数据类型(字符串、数字、布尔值等);
  • 支持自定义分隔符(如分号,适配欧洲地区格式);
  • 可导出为 CSV、XLSX、XLS 等多种格式;
  • 对简单或复杂数据结构(嵌套列表、字典列表)均有良好支持。

安装步骤

通过 pip 即可快速安装**Spire.XLS for Python**,在终端或命令提示符中运行:

复制代码
pip install Spire.XLS

安装完成后,即可直接导入模块开始编码。

Python 将一维列表导出为 CSV 文件

一维列表是简单的序列值(如 ["苹果", "香蕉", "樱桃"])。 以下是将这些值写入 CSV 中的单行或单列的步骤。

步骤 1:导入 Spire.XLS 模块

首先,从**Spire.XLS**导入必要的类:

复制代码
from spire.xls import *
from spire.xls.common import *

步骤2:创建工作簿与工作表

Spire.XLS 使用工作簿和工作表来组织数据。我们将创建一个新的工作簿并添加一个新的工作表:

复制代码
# 初始化工作簿
workbook = Workbook()
# 清除默认工作表,新建一个工作表
workbook.Worksheets.Clear()
worksheet = workbook.Worksheets.Add("一维列表")

步骤 3:将一维列表数据写入工作表

可以选择将列表写入单行 (水平)或单列(垂直)。

示例 1:将一维列表写入单行

复制代码
data_list = ["苹果", "香蕉", "橙子", "葡萄", "芒果"]
# 循环写入第1行,列索引从1开始
for i, item in enumerate(data_list):
   worksheet.Range[1, i+1].Value = item

示例 2:将一维列表写入单列

复制代码
data_list = ["苹果", "香蕉", "橙子", "葡萄", "芒果"]
# 循环写入第1列,行索引从1开始
for i, item in enumerate(data_list):
   worksheet.Range[i+1, 1].Value = item

步骤 4:将工作表保存为 CSV 文件

使用 SaveToFile() 将工作簿导出为 CSV 文件。指定 FileFormat.CSV 以确保正确的格式:

复制代码
# 指定文件格式为CSV
workbook.SaveToFile("一维列表.csv", FileFormat.CSV)
# 释放资源
workbook.Dispose()

输出效果:

Python 将二维列表导出为 CSV 文件

二维列表是"列表的列表",适合表示表格数据(如包含表头和多行记录),每个内部列表对应 CSV 的一行。

二维列表输出为 CSV 格式的 Python 代码:

复制代码
from spire.xls import *
from spire.xls.common import *

# 初始化工作簿与工作表
workbook = Workbook()
workbook.Worksheets.Clear()
worksheet = workbook.Worksheets.Add("二维列表")

# 示例二维列表(含表头和数据)
data = [
    ["姓名", "年龄", "城市", "员工号"],
    ["小张", 30, "北京", 1001],
    ["小王", 25, "广东", 1069],
    ["小李", 35, "天津", 2078],
    ["小孙", 28, "武汉", 2692]
]

# 双层循环写入行和列
for row_idx, row_data in enumerate(data):
    for col_idx, cell_data in enumerate(row_data):
        # 转换为字符串确保兼容性
        worksheet.Range[row_idx+1, col_idx+1].Value = str(cell_data)

# 保存为CSV
workbook.SaveToFile("二维列表.csv", FileFormat.CSV)
workbook.Dispose()

关键说明:

  • 适合结构化表格数据(带表头);
  • 通过嵌套循环遍历行和列;
  • 所有值转为字符串,避免数据类型冲突。

输出效果:

扩展技巧:生成的 CSV 可以 转换为 PDF 用于安全展示,或 转换为 JSON 用于 Web/API 数据交换。

Python 将字典列表导出为 CSV 文件

字典列表(如 [{"姓名": "小张", "年龄": 30}, ...])适合处理带字段名的数据,字典的键作为 CSV 表头,值作为行数据。

字典列表输出为 CSV 格式的 Python 代码:

复制代码
from spire.xls import *
from spire.xls.common import *

# 初始化工作簿与工作表
workbook = Workbook()
workbook.Worksheets.Clear()
worksheet = workbook.Worksheets.Add("字典列表")

# 示例字典列表
customer_list = [
    {"客户ID": 101, "姓名": "小张", "邮箱": "zhang@example.com
				document.getElementById('cloak4c6b695d14e123b28d762dfe5791389e').innerHTML = '';
				var prefix = 'ma' + 'il' + 'to';
				var path = 'hr' + 'ef' + '=';
				var addy4c6b695d14e123b28d762dfe5791389e = 'zhang' + '@';
				addy4c6b695d14e123b28d762dfe5791389e = addy4c6b695d14e123b28d762dfe5791389e + 'example' + '.' + 'com';
				var addy_text4c6b695d14e123b28d762dfe5791389e = 'zh&#97;ng' + '&#64;' + '&#101;x&#97;mpl&#101;' + '&#46;' + 'c&#111;m';document.getElementById('cloak4c6b695d14e123b28d762dfe5791389e').innerHTML += '<a ' + path + '\'' + prefix + ':' + addy4c6b695d14e123b28d762dfe5791389e + '\'>'+addy_text4c6b695d14e123b28d762dfe5791389e+'<\/a>';
		"},
    {"客户ID": 102, "姓名": "小王", "邮箱": "wang@example.com
				document.getElementById('cloak014772be6786c8a1655f25d7d3fe4819').innerHTML = '';
				var prefix = '&#109;a' + 'i&#108;' + '&#116;o';
				var path = 'hr' + 'ef' + '=';
				var addy014772be6786c8a1655f25d7d3fe4819 = 'w&#97;ng' + '&#64;';
				addy014772be6786c8a1655f25d7d3fe4819 = addy014772be6786c8a1655f25d7d3fe4819 + '&#101;x&#97;mpl&#101;' + '&#46;' + 'c&#111;m';
				var addy_text014772be6786c8a1655f25d7d3fe4819 = 'w&#97;ng' + '&#64;' + '&#101;x&#97;mpl&#101;' + '&#46;' + 'c&#111;m';document.getElementById('cloak014772be6786c8a1655f25d7d3fe4819').innerHTML += '<a ' + path + '\'' + prefix + ':' + addy014772be6786c8a1655f25d7d3fe4819 + '\'>'+addy_text014772be6786c8a1655f25d7d3fe4819+'<\/a>';
		"},
    {"客户ID": 103, "姓名": "小孙", "邮箱": "sun@example.com
				document.getElementById('cloak8c1dbb75892e18ea2760fa760ed30c0f').innerHTML = '';
				var prefix = '&#109;a' + 'i&#108;' + '&#116;o';
				var path = 'hr' + 'ef' + '=';
				var addy8c1dbb75892e18ea2760fa760ed30c0f = 's&#117;n' + '&#64;';
				addy8c1dbb75892e18ea2760fa760ed30c0f = addy8c1dbb75892e18ea2760fa760ed30c0f + '&#101;x&#97;mpl&#101;' + '&#46;' + 'c&#111;m';
				var addy_text8c1dbb75892e18ea2760fa760ed30c0f = 's&#117;n' + '&#64;' + '&#101;x&#97;mpl&#101;' + '&#46;' + 'c&#111;m';document.getElementById('cloak8c1dbb75892e18ea2760fa760ed30c0f').innerHTML += '<a ' + path + '\'' + prefix + ':' + addy8c1dbb75892e18ea2760fa760ed30c0f + '\'>'+addy_text8c1dbb75892e18ea2760fa760ed30c0f+'<\/a>';
		"}
]

# 提取表头并写入第1行(若列表非空)
if customer_list:
    headers = list(customer_list[0].keys())
    # 写入表头
    for col_idx, header in enumerate(headers):
        worksheet.Range[1, col_idx+1].Value = str(header)
    
    # 写入数据行(从第2行开始)
    for row_idx, record in enumerate(customer_list):
        for col_idx, header in enumerate(headers):
            # 安全获取值,缺失键时用空字符串
            value = record.get(header, "")
            worksheet.Range[row_idx+2, col_idx+1].Value = str(value)

# 保存为CSV
workbook.SaveToFile("字典列表.csv", FileFormat.CSV)
workbook.Dispose()

关键说明:

  • 表头从第一个字典的键中提取;
  • 使用 record.get(header, "") 处理可能的缺失键;
  • 严格按表头顺序排列列,确保数据对齐。

输出效果:

进阶:自定义分隔符与编码

Spire.XLS 支持灵活设置 CSV 文件的分隔符(默认逗号)和编码,适配不同地区或系统需求。通过 Worksheet.SaveToFile() 方法的参数指定:

复制代码
# 分号分隔(欧洲常用),UTF-8编码
worksheet.SaveToFile("分号分隔.csv", ";", Encoding.get_UTF8())

# 制表符分隔,UTF-8编码
worksheet.SaveToFile("制表符分隔.csv", "\t", Encoding.get_UTF8())

# 逗号分隔,Unicode编码
worksheet.SaveToFile("Unicode编码.csv", ",", Encoding.get_Unicode())

总结

借助 Spire.XLS for Python,无论是简单的一维列表、结构化的二维列表,还是带字段名的字典列表,都能高效导出到 CSV 文件。只需根据数据结构选择对应方法,即可确保转换准确、输出专业。

常见问题解答

1. 导出列表到 CSV 格式的最佳实践是什么?

  • 转换前验证数据格式(如缺失值、异常类型);
  • 用 try-catch 块捕获异常(如文件权限错误);
  • 大型数据集先通过样本测试;
  • 完成后调用 Dispose() 释放资源。

2. 如何一次性导出多个列表到不同 CSV 文件?

通过循环遍历列表字典,逐个保存:

复制代码
lists = {
    "水果": ["苹果", "香蕉", "樱桃"],
    "分数": [85, 92, 78]
}

for name, data in lists.items():
    wb = Workbook()
    wb.Worksheets.Clear()
    ws = wb.Worksheets.Add(name)
    for i, val in enumerate(data):
        ws.Range[i+1, 1].Value = str(val)
    wb.SaveToFile(f"{name}.csv", FileFormat.CSV)
    wb.Dispose()

3. 如何在 CSV 文件中格式化数字(如货币、小数)?

CSV 以文本存储数字,需提前设置格式:

复制代码
# 设置A1:A10为货币格式($1,234.56)
ws.Range["A1:A10"].NumberFormat = "$#,##0.00"

4. Spire.XLS for Python 支持哪些操作系统?

全平台支持,包括 Windows、macOS 和 Linux。

相关推荐
Blossom.11840 分钟前
大模型知识蒸馏实战:从Qwen-72B到Qwen-7B的压缩艺术
大数据·人工智能·python·深度学习·算法·机器学习·pygame
guygg881 小时前
Alpha稳定分布概率密度函数的MATLAB实现
开发语言·matlab
刘逸潇20051 小时前
Socket:TCP/UDP通信详解
python·websocket·udp·tcp
The_Second_Coming1 小时前
Python 学习笔记:基础篇
运维·笔记·python·学习
诗句藏于尽头1 小时前
python实战学习记录
python·学习
草莓熊Lotso1 小时前
C++ 二叉搜索树(BST)完全指南:从概念原理、核心操作到底层实现
java·运维·开发语言·c++·人工智能·经验分享·c++进阶
oliveira-time2 小时前
单例模式中的饿汉式
java·开发语言
AI松子6662 小时前
PyTorch-混合精度训练(amp)
人工智能·pytorch·python
MDLZH2 小时前
Pytorch性能调优简单总结
人工智能·pytorch·python