将 Python 列表导出为 Excel 文件:一维、二维、字典列表

在 Python 数据处理场景中,将列表(List)数据导出为 Excel 文件是高频需求(如数据报表、批量数据导出等)。相比于传统的openpyxlxlwt等库,Free Spire.XLS for Python 是一款免费的 Excel 处理库,无需依赖 Microsoft Excel,支持完整的 Excel 文件创建、编辑和格式设置,尤其适合新手快速实现列表到 Excel 的转换。

本文将从环境准备、基础示例到进阶优化演示如何用 Free Spire.XLS for Python 实现列表转 Excel,覆盖以下核心场景:

  • 基础实战:导出一维列表到 Excel(单列)
  • 进阶实战:导出二维列表到 Excel(带表头)
  • 实战拓展:导出字典列表到 Excel(贴合业务场景)

1. 安装免费库

Free Spire.XLS for Python 支持 Python 3.6 及以上版本,通过 pip即可安装:

bash 复制代码
pip install Spire.XLS.Free

2. 基础实战:导出一维列表到 Excel(单列)

实现思路

  1. 创建空白工作簿,获取默认工作表;
  2. 遍历一维列表,将每个元素写入 Excel 的指定列(如A列);
  3. 保存 Excel 文件并释放资源。

Python 代码

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

# 定义要转换的一维列表
one_dimensional_list = ["Python", "Java", "C++", "JavaScript", "Go"]

# 1. 创建工作簿对象
workbook = Workbook()
# 2. 获取第一个工作表(默认创建)
worksheet = workbook.Worksheets[0]
# 3. 设置工作表名称
worksheet.Name = "编程语言列表"

# 4. 遍历列表,写入Excel(从第1行第1列开始)
for index, value in enumerate(one_dimensional_list):
    # 行号从1开始
    row = index + 1
    # 写入A列(第1列)
    worksheet.Range[row, 1].Text = value

# 5. 保存Excel文件(支持.xlsx/.xls/.xlsm等格式)
output_path = "一维列表转Excel.xlsx"
workbook.SaveToFile(output_path, FileFormat.Version2016)

# 6. 释放资源(重要,避免内存泄漏)
workbook.Dispose()

print(f"一维列表已成功导出到:{output_path}")

代码解析

  • Workbook():创建 Excel 工作簿对象,相当于新建一个 Excel 文件;
  • Worksheets[0]:获取工作簿中第一个工作表(索引从0开始);
  • Range[row, col]:定位 Excel 单元格,行/列号均从1开始
  • Text:设置单元格的文本内容;
  • SaveToFile():保存文件,第二个参数指定Excel版本;
  • Dispose():释放工作簿资源,避免占用内存。

效果图:


3. 进阶实战:导出二维列表到 Excel(带表头)

实现思路

  1. 定义二维列表(包含表头和数据);
  2. 先写入表头行,再遍历数据行逐行写入;
  3. 可选:设置表头样式(加粗、居中)提升可读性。

完整代码

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

# 定义二维列表(表头+数据)
two_dimensional_list = [
    ["姓名", "年龄", "城市", "职业"],  # 表头
    ["张三", 28, "北京", "工程师"],
    ["李四", 32, "上海", "产品经理"],
    ["王五", 25, "广州", "设计师"],
    ["赵六", 30, "深圳", "开发工程师"]
]

# 1. 创建工作簿
workbook = Workbook()
worksheet = workbook.Worksheets[0]
worksheet.Name = "人员信息表"

# 2. 遍历二维列表,逐行写入Excel
for row_index, row_data in enumerate(two_dimensional_list):
    # Excel行号从1开始
    current_row = row_index + 1
    for col_index, cell_value in enumerate(row_data):
        # Excel列号从1开始
        current_col = col_index + 1
        # 写入单元格内容
        worksheet.Range[current_row, current_col].Text = str(cell_value)
        
        # 3. 优化表头样式(加粗、居中)
        if current_row == 1:
            worksheet.Range[current_row, current_col].Style.Font.IsBold = True
            worksheet.Range[current_row, current_col].Style.HorizontalAlignment = HorizontalAlignType.Center

# 4. 自动调整列宽(适配内容长度)
worksheet.AllocatedRange.AutoFitColumns()

# 5. 保存文件
output_path = "二维列表转Excel.xlsx"
workbook.SaveToFile(output_path, FileFormat.Version2016)
workbook.Dispose()

print(f"二维列表已成功导出到:{output_path}")

代码解析

  • 二维列表遍历:外层循环控制行,内层循环控制列,实现"逐行逐列"写入;
  • 表头样式优化:通过 IsBold = True 设置加粗, HorizontalAlignType.Center 设置水平居中;
  • AllocatedRange.AutoFitColumns():自动调整列宽,避免内容被截断;
  • 数据类型转换:str(cell_value)确保数字、字符串等类型统一写入,避免类型报错。

效果图:


4. 实战拓展:导出字典列表到 Excel(贴合业务场景)

字典列表是 Python 业务开发中最常用的数据格式(如从数据库/接口获取的结构化数据),每个字典代表一行数据,字典的 对应Excel表头,对应单元格数据。以下是完整实现方案。

实现思路

  1. 定义字典列表(每个字典的键为字段名,值为字段值);
  2. 提取字典的键作为 Excel 表头(需确保字典键一致,或兼容键缺失场景);
  3. 先写入表头行并设置样式,再遍历字典列表,按表头顺序提取值写入单元格;
  4. 自动调整列宽,提升 Excel 可读性。

完整代码

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

# 定义字典列表(模拟业务场景:从接口/数据库获取的用户数据)
dict_list = [
    {"用户ID": 1001, "姓名": "张三", "年龄": 28, "城市": "北京", "注册时间": "2024-01-15"},
    {"用户ID": 1002, "姓名": "李四", "年龄": 32, "城市": "上海", "注册时间": "2024-02-20"},
    {"用户ID": 1003, "姓名": "王五", "年龄": 25, "城市": "广州", "注册时间": "2024-03-10"},
    {"用户ID": 1004, "姓名": "赵六", "年龄": 30, "城市": "深圳", "注册时间": "2024-04-05"}
]

# 1. 创建工作簿和工作表
workbook = Workbook()
worksheet = workbook.Worksheets[0]
worksheet.Name = "用户信息表(字典列表)"

# 2. 提取表头(字典的键)
if not dict_list:
    print("字典列表为空,无需导出!")
    workbook.Dispose()
    exit()
# 以第一个字典的键作为表头(确保所有字典键一致,或参考下方注意事项处理)
headers = list(dict_list[0].keys())

# 3. 写入表头行并设置样式
for col_index, header in enumerate(headers):
    current_col = col_index + 1
    # 写入表头文本
    worksheet.Range[1, current_col].Text = header

# 4. 遍历字典列表,写入数据行
for row_idx, data_dict in enumerate(dict_list):
    current_row = row_idx + 2  # 表头占第1行,数据从第2行开始
    for col_idx, header in enumerate(headers):
        current_col = col_idx + 1
        # 提取字典值(用get方法兼容键缺失场景,避免KeyError)
        cell_value = data_dict.get(header, "")
        # 写入单元格(统一转字符串,避免类型报错)
        worksheet.Range[current_row, current_col].Text = str(cell_value)

# 5. 自动调整列宽(适配内容长度)
worksheet.AllocatedRange.AutoFitColumns()

# 6. 保存Excel文件
output_path = "字典列表转Excel.xlsx"
workbook.SaveToFile(output_path, FileFormat.Version2016)

# 7. 释放资源
workbook.Dispose()

print(f"字典列表已成功导出到:{output_path}")

代码解析

  • 表头提取list(dict_list[0].keys()) 从第一个字典中提取所有键作为 Excel 表头,是业务场景中最常用的方式;
  • 兼容键缺失data_dict.get(header, "") 替代直接取值data_dict[header],若某个字典缺失指定键,会填充空字符串,避免KeyError报错;
  • 行号计算 :数据行从第2行开始(current_row = row_idx + 2),因为第1行已写入表头;

效果图:


5. 常见问题与注意事项

  1. 免费版限制:Free Spire.XLS for Python 在读写 .xls 格式的 Excel 文档时,有每个文档 5 个工作表,每个工作表 200 行的限制。读写 .xlsx 格式的 Excel 文档时没有任何限制;
  2. 中文乱码问题:若导出的Excel出现中文乱码,需确保代码文件编码为 UTF-8,且写入时直接使用字符串(无需额外转码);
  3. 资源释放 :务必调用 Dispose() 释放工作簿资源,否则可能导致文件被占用(无法删除/修改);
  4. 文件格式FileFormat.Version2016 对应.xlsx格式,FileFormat.Excel97to2003 对应.xls格式(兼容旧版Excel);
  5. 字典列表兼容 :若字典键不一致,优先提取所有唯一键作为表头,并用get方法取值避免报错。
python 复制代码
# 提取所有唯一键作为表头
all_headers = set()
for d in dict_list:
    all_headers.update(d.keys())
headers = sorted(list(all_headers))  # 排序保证表头顺序固定

通过本文的示例,你可以快速实现从简单的一维列表到贴合业务场景的字典列表导出,满足日常数据报表、批量导出等场景需求。如果需要更复杂的 Excel 操作(如合并单元格设置单元格颜色、插入公式等),可参考官方示例文档进一步拓展。

相关推荐
Swizard8 小时前
别再让你的 Python 傻等了:三分钟带你通过 asyncio 实现性能起飞
python
代码or搬砖9 小时前
String字符串
android·java·开发语言
leo__52010 小时前
基于两步成像算法的聚束模式SAR MATLAB实现
开发语言·算法·matlab
Darkershadow10 小时前
python学习之串口通信
python·学习
Macbethad11 小时前
自动化测试技术报告
开发语言·lua
38242782711 小时前
python:输出JSON
前端·python·json
不会画画的画师11 小时前
Go开发指南:io/ioutil包应用和迁移指南
开发语言·后端·golang
2503_9284115611 小时前
12.22 wxml语法
开发语言·前端·javascript
59803541511 小时前
【java工具类】小数、整数转中文大写
android·java·开发语言