查看: 301|回复: 3

Python列表导出Excel的三种场景:Spire.XLS与pandas/openpyxl/xlsxwriter实战

[复制链接]
发表于 昨天 12:00 | 显示全部楼层 |阅读模式
在日常数据处理中,将 Python 列表结构的数据导出为 Excel 文件是高频操作。无论是一维列表(如产品名列表)、二维列表(多行多列表格)还是字典列表(API 响应或数据库查询结果),都需要一种简洁高效的方法写入 Excel。本文综合介绍 Free Spire.XLS for Python、pandas、openpyxl 和 xlsxwriter 四种方案,覆盖从简单导出到样式控制的完整需求。

环境准备

Free Spire.XLS for Python 是一款无需依赖 Microsoft Office 的 Excel 处理组件,支持 .xls 与 .xlsx 格式,免费版对工作表数量和数据行数有一定限制。安装:
  1. pip install Spire.Xls.Free
复制代码
导入核心模块:
  1. from spire.xls import *
  2. from spire.xls.common import *
复制代码
核心对象包括 Workbook(工作簿)、Worksheet(工作表)和 CellRange(单元格区域),构成了操作的基础层级。

pandas、openpyxl、xlsxwriter 是 Python 生态中更通用的 Excel 写库,安装:
  1. pip install pandas openpyxl xlsxwriter
复制代码
pandas 默认使用 openpyxl 作为引擎,安装后即可通过 to_excel 一行导出。

场景 1:一维列表导出为单列

一维列表对应 Excel 中的单列数据。使用 Spire.XLS 时,需遍历列表按行索引写入单元格,行号从 1 开始。
  1. from spire.xls import *
  2. from spire.xls.common import *
  3. def list_to_single_column(data_list, output_path, sheet_name="数据"):
  4.     workbook = Workbook()
  5.     workbook.Worksheets.Clear()
  6.     sheet = workbook.Worksheets.Add(sheet_name)
  7.     for index, value in enumerate(data_list):
  8.         sheet.Range[index + 1, 1].Value = str(value)
  9.     sheet.AllocatedRange.AutoFitColumns()
  10.     workbook.SaveToFile(output_path, ExcelVersion.Version2016)
  11.     workbook.Dispose()
  12. if __name__ == "__main__":
  13.     products = ["笔记本电脑", "机械键盘", "无线鼠标", "27寸显示器", "外接硬盘"]
  14.     list_to_single_column(products, "single_column.xlsx")
复制代码

要点:行号列号从 1 开始;Value 属性自动转字符串,若需保留数值类型可使用 NumberValue;AutoFitColumns() 方法根据内容调整列宽。

若使用 pandas,一维列表导出为单列更简洁:
  1. import pandas as pd
  2. data = ["苹果", "香蕉", "橙子", "葡萄"]
  3. df = pd.DataFrame(data, columns=["水果名称"])
  4. df.to_excel("fruits.xlsx", index=False)
复制代码

场景 2:二维列表导出为结构化表格

二维列表的每个子列表对应一行数据,通常配合表头。使用 Spire.XLS 时需分离表头与数据行,对表头应用样式。
  1. from spire.xls import *
  2. from spire.xls.common import *
  3. def list_2d_to_excel(headers, data_rows, output_path, sheet_name="数据表"):
  4.     workbook = Workbook()
  5.     workbook.Worksheets.Clear()
  6.     sheet = workbook.Worksheets.Add(sheet_name)
  7.     # 写入表头(第1行)
  8.     for col_idx, header in enumerate(headers):
  9.         cell = sheet.Range[1, col_idx + 1]
  10.         cell.Value = header
  11.         cell.Style.Font.IsBold = True
  12.         cell.Style.Color = Color.get_LightBlue()
  13.         cell.Style.HorizontalAlignment = HorizontalAlignType.Center
  14.     # 写入数据行(从第2行开始)
  15.     for row_idx, row_data in enumerate(data_rows):
  16.         for col_idx, value in enumerate(row_data):
  17.             cell = sheet.Range[row_idx + 2, col_idx + 1]
  18.             if isinstance(value, (int, float)):
  19.                 cell.NumberValue = float(value)
  20.             else:
  21.                 cell.Value = str(value)
  22.     # 添加边框
  23.     data_range = sheet.Range[1, 1, len(data_rows) + 1, len(headers)]
  24.     data_range.BorderAround(LineStyleType.Thin)
  25.     data_range.BorderInside(LineStyleType.Thin)
  26.     sheet.AllocatedRange.AutoFitColumns()
  27.     workbook.SaveToFile(output_path, ExcelVersion.Version2016)
  28.     workbook.Dispose()
  29. if __name__ == "__main__":
  30.     headers = ["员工ID", "姓名", "部门", "月薪", "在职状态"]
  31.     employees = [
  32.         [1001, "张明", "研发部", 15000, True],
  33.         [1002, "李华", "产品部", 13500, True],
  34.         [1003, "王芳", "设计部", 12800, False],
  35.         [1004, "赵强", "测试部", 11500, True]
  36.     ]
  37.     list_2d_to_excel(headers, employees, "employee_table.xlsx")
复制代码

技术细节:数值用 NumberValue 写入以便参与公式计算;布尔值直接写入显示为 TRUE/FALSE,可自定义转换;区域批量操作通过 Range[行1,列1,行2,列2] 设置。

使用 pandas 同样简单:
  1. data = [
  2.     ["张三", 25, "北京"],
  3.     ["李四", 30, "上海"],
  4.     ["王五", 28, "广州"]
  5. ]
  6. df = pd.DataFrame(data, columns=["姓名", "年龄", "城市"])
  7. df.to_excel("people.xlsx", index=False)
复制代码

若多个一维列表合并为多列,可构造字典:
  1. names = ["张三", "李四", "王五"]
  2. ages = [25, 30, 28]
  3. cities = ["北京", "上海", "广州"]
  4. df = pd.DataFrame({"姓名": names, "年龄": ages, "城市": cities})
  5. df.to_excel("people2.xlsx", index=False)
复制代码

场景 3:字典列表导出为 Excel

字典列表(如数据库查询结果)每个元素是一个字典,键对应列名。使用 Spire.XLS 时需提取键作为表头,然后遍历写入。
  1. from spire.xls import *
  2. from spire.xls.common import *
  3. def dict_list_to_excel(dict_list, output_path, sheet_name="数据", custom_headers=None):
  4.     if not dict_list:
  5.         raise ValueError("数据列表不能为空")
  6.     workbook = Workbook()
  7.     workbook.Worksheets.Clear()
  8.     sheet = workbook.Worksheets.Add(sheet_name)
  9.     # 确定表头
  10.     if custom_headers:
  11.         headers = custom_headers
  12.         keys = list(dict_list[0].keys())
  13.     else:
  14.         keys = list(dict_list[0].keys())
  15.         headers = keys
  16.     # 写入表头
  17.     for col_idx, header in enumerate(headers):
  18.         cell = sheet.Range[1, col_idx + 1]
  19.         cell.Value = header
  20.         cell.Style.Font.IsBold = True
  21.         cell.Style.HorizontalAlignment = HorizontalAlignType.Center
  22.     # 写入数据
  23.     for row_idx, item in enumerate(dict_list):
  24.         for col_idx, key in enumerate(keys):
  25.             cell = sheet.Range[row_idx + 2, col_idx + 1]
  26.             value = item.get(key, "")
  27.             if value is None:
  28.                 cell.Value = ""
  29.             elif isinstance(value, bool):
  30.                 cell.BooleanValue = value
  31.             elif isinstance(value, (int, float)):
  32.                 cell.NumberValue = float(value)
  33.             else:
  34.                 cell.Value = str(value)
  35.     data_range = sheet.Range[1, 1, len(dict_list) + 1, len(headers)]
  36.     data_range.BorderAround(LineStyleType.Thin)
  37.     data_range.BorderInside(LineStyleType.Thin)
  38.     sheet.AllocatedRange.AutoFitColumns()
  39.     workbook.SaveToFile(output_path, ExcelVersion.Version2016)
  40.     workbook.Dispose()
  41. if __name__ == "__main__":
  42.     orders = [
  43.         {"order_id": "ORD2024001", "product": "笔记本支架", "quantity": 2, "price": 89.9, "status": "已发货"},
  44.         {"order_id": "ORD2024002", "product": "USB集线器", "quantity": 5, "price": 45.0, "status": "待出库"},
  45.         {"order_id": "ORD2024003", "product": "散热底座", "quantity": 1, "price": 129.0, "status": "已签收"},
  46.     ]
  47.     dict_list_to_excel(orders, "orders.xlsx", sheet_name="订单数据")
复制代码

设计考量:通过 isinstance 判断数据类型,分别调用 BooleanValue、NumberValue;None 写为空字符串;未匹配类型统一转字符串,确保导出不中断。

使用 pandas 时,字典列表可直接构造 DataFrame:
  1. orders_df = pd.DataFrame(orders)
  2. orders_df.to_excel("orders_pandas.xlsx", index=False)
复制代码

知识扩展:其他库的使用与对比

— openpyxl 适用于需要细粒度控制单元格样式、合并单元格的场景。将二维列表逐行写入:
  1. from openpyxl import Workbook
  2. data = [
  3.     ["姓名", "年龄", "城市"],
  4.     ["张三", 25, "北京"],
  5.     ["李四", 30, "上海"],
  6.     ["王五", 28, "广州"]
  7. ]
  8. wb = Workbook()
  9. ws = wb.active
  10. for row in data:
  11.     ws.append(row)
  12. wb.save("openpyxl_output.xlsx")
复制代码

写入一维列表为单列时,每个元素以 [element] 形式 append。

— xlsxwriter 支持样式、图表、条件格式,适合生成专业报表。基本写入:
  1. import xlsxwriter
  2. workbook = xlsxwriter.Workbook('xlsxwriter_output.xlsx')
  3. worksheet = workbook.add_worksheet()
  4. data = [
  5.     ["姓名", "年龄", "城市"],
  6.     ["张三", 25, "北京"],
  7.     ["李四", 30, "上海"],
  8. ]
  9. for row_idx, row_data in enumerate(data):
  10.     for col_idx, value in enumerate(row_data):
  11.         worksheet.write(row_idx, col_idx, value)
  12. workbook.close()
复制代码

添加格式:
  1. header_format = workbook.add_format({'bold': True, 'font_color': 'white', 'bg_color': '#4CAF50', 'border': 1})
  2. for col, header in enumerate(["姓名", "年龄", "城市"]):
  3.     worksheet.write(0, col, header, header_format)
复制代码

xlsxwriter 也支持多个工作表:worksheet1 = workbook.add_worksheet("Sheet1"); worksheet2 = workbook.add_worksheet("Sheet2")。

总结

将 Python 列表导出为 Excel 的核心在于数据结构到表格结构的映射:一维列表→单列,二维列表→多行多列,字典列表→带标题行。简易场景下可直接用 Spire.XLS 手动遍历,或使用 pandas 一行代码完成;复杂样式需求可选 openpyxl 或 xlsxwriter。实际开发中建议根据数据规模、格式要求选择最合适的库,并封装成通用函数加入类型判断与异常处理,以提高代码复用性和健壮性。
回复

使用道具 举报

发表于 昨天 12:10 | 显示全部楼层

Re: Python列表导出Excel的三种场景:Spire.XLS与pandas/openpyxl/xlsxwriter实战

非常感谢分享,写得非常详细!尤其是 Spire.XLS 的用法,之前我只用过 pandas,看了代码中对单元格样式和边框的手动控制,感觉更灵活了。想请教一下,场景2和场景3里,openpyxl 和 xlsxwriter 相比 Spire.XLS 在性能或功能上有哪些明显的差异?期待后续内容~
回复 支持 反对

使用道具 举报

发表于 昨天 12:10 | 显示全部楼层

Re: Python列表导出Excel的三种场景:Spire.XLS与pandas/openpyxl/xlsxwriter实战

感谢楼主的详细分享!文章把一维列表、二维列表两种典型场景都讲清楚了,而且同时给出了 Spire.XLS 和 pandas 两种写法的对比,对新手很友好。特别注意到 Spire.XLS 示例中处理数值类型时用了 `NumberValue`,这个细节确实容易忽略,很多人直接赋字符串会导致 Excel 里存成文本。另外 `AutoFitColumns` 和边框的添加也让导出的表格更接近正式报表,实用性强。 我平时主要用 pandas + openpyxl 组合,没怎么接触过 Free Spire.XLS。想请教一下,免费版对行数和工作表数量的限制具体是多少?当数据量稍大时,Spire.XLS 和 pandas 在性能上差距大吗?期待楼主后续能补上字典列表(比如 `[{“a”:1}, {“b”:2}]`)的写法,那在 API 数据处理中也很常见。再次感谢分享!
回复 支持 反对

使用道具 举报

发表于 昨天 12:10 | 显示全部楼层

Re: Python列表导出Excel的三种场景:Spire.XLS与pandas/openpyxl/xlsxwriter实战

感谢分享,很实用的总结!我平时主要用 pandas + openpyxl 处理导出,但看到 Spire.XLS 在样式控制上确实更灵活,尤其是一步步设置边框和颜色,适合对格式有要求的报表。想问一下,免费版对数据行数的具体限制是多少?如果二维列表有几千行数据,会不会触发限制导致保存失败?另外,你提到 AutoFitColumns 调整列宽,但对于中文内容,有时自动列宽会不够,有没有推荐的固定列宽设置方法?
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

指导单位

江苏省公安厅

江苏省通信管理局

浙江省台州刑侦支队

DEFCON GROUP 86025

Hacking Group 021A

旗下站点

态势感知中心

应急响应中心

红盟安全

联系我们

官方QQ群:112851260

官方邮箱:security#ihonker.org(#改成@)

官方核心成员

关注微信公众号

Archiver|手机版|小黑屋| ( 沪ICP备2021026908号 )

GMT+8, 2026-6-26 01:55 , Processed in 0.034269 second(s), 17 queries , Gzip On, Redis On.

Powered by ihonker.com

Copyright © 2015-现在.

  • 返回顶部