在日常数据处理中,将 Python 列表结构的数据导出为 Excel 文件是高频操作。无论是一维列表(如产品名列表)、二维列表(多行多列表格)还是字典列表(API 响应或数据库查询结果),都需要一种简洁高效的方法写入 Excel。本文综合介绍 Free Spire.XLS for Python、pandas、openpyxl 和 xlsxwriter 四种方案,覆盖从简单导出到样式控制的完整需求。
环境准备
Free Spire.XLS for Python 是一款无需依赖 Microsoft Office 的 Excel 处理组件,支持 .xls 与 .xlsx 格式,免费版对工作表数量和数据行数有一定限制。安装:- pip install Spire.Xls.Free
复制代码 导入核心模块:- from spire.xls import *
- from spire.xls.common import *
复制代码 核心对象包括 Workbook(工作簿)、Worksheet(工作表)和 CellRange(单元格区域),构成了操作的基础层级。
pandas、openpyxl、xlsxwriter 是 Python 生态中更通用的 Excel 写库,安装:- pip install pandas openpyxl xlsxwriter
复制代码 pandas 默认使用 openpyxl 作为引擎,安装后即可通过 to_excel 一行导出。
场景 1:一维列表导出为单列
一维列表对应 Excel 中的单列数据。使用 Spire.XLS 时,需遍历列表按行索引写入单元格,行号从 1 开始。- from spire.xls import *
- from spire.xls.common import *
- def list_to_single_column(data_list, output_path, sheet_name="数据"):
- workbook = Workbook()
- workbook.Worksheets.Clear()
- sheet = workbook.Worksheets.Add(sheet_name)
- for index, value in enumerate(data_list):
- sheet.Range[index + 1, 1].Value = str(value)
- sheet.AllocatedRange.AutoFitColumns()
- workbook.SaveToFile(output_path, ExcelVersion.Version2016)
- workbook.Dispose()
- if __name__ == "__main__":
- products = ["笔记本电脑", "机械键盘", "无线鼠标", "27寸显示器", "外接硬盘"]
- list_to_single_column(products, "single_column.xlsx")
复制代码
要点:行号列号从 1 开始;Value 属性自动转字符串,若需保留数值类型可使用 NumberValue;AutoFitColumns() 方法根据内容调整列宽。
若使用 pandas,一维列表导出为单列更简洁:- import pandas as pd
- data = ["苹果", "香蕉", "橙子", "葡萄"]
- df = pd.DataFrame(data, columns=["水果名称"])
- df.to_excel("fruits.xlsx", index=False)
复制代码
场景 2:二维列表导出为结构化表格
二维列表的每个子列表对应一行数据,通常配合表头。使用 Spire.XLS 时需分离表头与数据行,对表头应用样式。- from spire.xls import *
- from spire.xls.common import *
- def list_2d_to_excel(headers, data_rows, output_path, sheet_name="数据表"):
- workbook = Workbook()
- workbook.Worksheets.Clear()
- sheet = workbook.Worksheets.Add(sheet_name)
- # 写入表头(第1行)
- for col_idx, header in enumerate(headers):
- cell = sheet.Range[1, col_idx + 1]
- cell.Value = header
- cell.Style.Font.IsBold = True
- cell.Style.Color = Color.get_LightBlue()
- cell.Style.HorizontalAlignment = HorizontalAlignType.Center
- # 写入数据行(从第2行开始)
- for row_idx, row_data in enumerate(data_rows):
- for col_idx, value in enumerate(row_data):
- cell = sheet.Range[row_idx + 2, col_idx + 1]
- if isinstance(value, (int, float)):
- cell.NumberValue = float(value)
- else:
- cell.Value = str(value)
- # 添加边框
- data_range = sheet.Range[1, 1, len(data_rows) + 1, len(headers)]
- data_range.BorderAround(LineStyleType.Thin)
- data_range.BorderInside(LineStyleType.Thin)
- sheet.AllocatedRange.AutoFitColumns()
- workbook.SaveToFile(output_path, ExcelVersion.Version2016)
- workbook.Dispose()
- if __name__ == "__main__":
- headers = ["员工ID", "姓名", "部门", "月薪", "在职状态"]
- employees = [
- [1001, "张明", "研发部", 15000, True],
- [1002, "李华", "产品部", 13500, True],
- [1003, "王芳", "设计部", 12800, False],
- [1004, "赵强", "测试部", 11500, True]
- ]
- list_2d_to_excel(headers, employees, "employee_table.xlsx")
复制代码
技术细节:数值用 NumberValue 写入以便参与公式计算;布尔值直接写入显示为 TRUE/FALSE,可自定义转换;区域批量操作通过 Range[行1,列1,行2,列2] 设置。
使用 pandas 同样简单:- data = [
- ["张三", 25, "北京"],
- ["李四", 30, "上海"],
- ["王五", 28, "广州"]
- ]
- df = pd.DataFrame(data, columns=["姓名", "年龄", "城市"])
- df.to_excel("people.xlsx", index=False)
复制代码
若多个一维列表合并为多列,可构造字典:- names = ["张三", "李四", "王五"]
- ages = [25, 30, 28]
- cities = ["北京", "上海", "广州"]
- df = pd.DataFrame({"姓名": names, "年龄": ages, "城市": cities})
- df.to_excel("people2.xlsx", index=False)
复制代码
场景 3:字典列表导出为 Excel
字典列表(如数据库查询结果)每个元素是一个字典,键对应列名。使用 Spire.XLS 时需提取键作为表头,然后遍历写入。- from spire.xls import *
- from spire.xls.common import *
- def dict_list_to_excel(dict_list, output_path, sheet_name="数据", custom_headers=None):
- if not dict_list:
- raise ValueError("数据列表不能为空")
- workbook = Workbook()
- workbook.Worksheets.Clear()
- sheet = workbook.Worksheets.Add(sheet_name)
- # 确定表头
- if custom_headers:
- headers = custom_headers
- keys = list(dict_list[0].keys())
- else:
- keys = list(dict_list[0].keys())
- headers = keys
- # 写入表头
- for col_idx, header in enumerate(headers):
- cell = sheet.Range[1, col_idx + 1]
- cell.Value = header
- cell.Style.Font.IsBold = True
- cell.Style.HorizontalAlignment = HorizontalAlignType.Center
- # 写入数据
- for row_idx, item in enumerate(dict_list):
- for col_idx, key in enumerate(keys):
- cell = sheet.Range[row_idx + 2, col_idx + 1]
- value = item.get(key, "")
- if value is None:
- cell.Value = ""
- elif isinstance(value, bool):
- cell.BooleanValue = value
- elif isinstance(value, (int, float)):
- cell.NumberValue = float(value)
- else:
- cell.Value = str(value)
- data_range = sheet.Range[1, 1, len(dict_list) + 1, len(headers)]
- data_range.BorderAround(LineStyleType.Thin)
- data_range.BorderInside(LineStyleType.Thin)
- sheet.AllocatedRange.AutoFitColumns()
- workbook.SaveToFile(output_path, ExcelVersion.Version2016)
- workbook.Dispose()
- if __name__ == "__main__":
- orders = [
- {"order_id": "ORD2024001", "product": "笔记本支架", "quantity": 2, "price": 89.9, "status": "已发货"},
- {"order_id": "ORD2024002", "product": "USB集线器", "quantity": 5, "price": 45.0, "status": "待出库"},
- {"order_id": "ORD2024003", "product": "散热底座", "quantity": 1, "price": 129.0, "status": "已签收"},
- ]
- dict_list_to_excel(orders, "orders.xlsx", sheet_name="订单数据")
复制代码
设计考量:通过 isinstance 判断数据类型,分别调用 BooleanValue、NumberValue;None 写为空字符串;未匹配类型统一转字符串,确保导出不中断。
使用 pandas 时,字典列表可直接构造 DataFrame:- orders_df = pd.DataFrame(orders)
- orders_df.to_excel("orders_pandas.xlsx", index=False)
复制代码
知识扩展:其他库的使用与对比
— openpyxl 适用于需要细粒度控制单元格样式、合并单元格的场景。将二维列表逐行写入:- from openpyxl import Workbook
- data = [
- ["姓名", "年龄", "城市"],
- ["张三", 25, "北京"],
- ["李四", 30, "上海"],
- ["王五", 28, "广州"]
- ]
- wb = Workbook()
- ws = wb.active
- for row in data:
- ws.append(row)
- wb.save("openpyxl_output.xlsx")
复制代码
写入一维列表为单列时,每个元素以 [element] 形式 append。
— xlsxwriter 支持样式、图表、条件格式,适合生成专业报表。基本写入:- import xlsxwriter
- workbook = xlsxwriter.Workbook('xlsxwriter_output.xlsx')
- worksheet = workbook.add_worksheet()
- data = [
- ["姓名", "年龄", "城市"],
- ["张三", 25, "北京"],
- ["李四", 30, "上海"],
- ]
- for row_idx, row_data in enumerate(data):
- for col_idx, value in enumerate(row_data):
- worksheet.write(row_idx, col_idx, value)
- workbook.close()
复制代码
添加格式:- header_format = workbook.add_format({'bold': True, 'font_color': 'white', 'bg_color': '#4CAF50', 'border': 1})
- for col, header in enumerate(["姓名", "年龄", "城市"]):
- 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。实际开发中建议根据数据规模、格式要求选择最合适的库,并封装成通用函数加入类型判断与异常处理,以提高代码复用性和健壮性。 |