尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Python 列表导出 Excel 完整教程:一维 / 二维 / 字典列表全覆盖

Python 列表导出 Excel 完整教程:一维 / 二维 / 字典列表全覆盖
📅 发布时间:2026/6/30 0:22:28

本文基于 Free Spire.XLS for Python 免费库,从一维列表、二维列表到字典列表三种典型场景,逐步讲解列表到 Excel 的转换实现。


环境准备

Free Spire.XLS for Python 是一款独立的 Excel 处理组件,无需依赖 Microsoft Office 环境,支持 .xls 与 .xlsx 格式的创建与编辑。免费版对工作表数量和数据行数有一定限制,适用于中小规模数据导出场景。

安装方式

通过 pip 直接安装免费版本:

pip install Spire.Xls.Free

安装完成后,在代码中引入核心模块:

from spire.xls import * from spire.xls.common import *

核心对象包括Workbook(工作簿)、Worksheet(工作表)和CellRange(单元格区域),三者构成了 Excel 操作的基础层级。


场景1:一维列表导出单列数据

一维列表是最简单的数据结构,通常对应 Excel 中的单列数据,例如产品名称列表、员工工号序列等。

实现思路

  1. 创建工作簿并获取工作表
  2. 遍历列表,按行索引依次写入单元格
  3. 调整列宽以优化显示效果
  4. 保存文件并释放资源

完整代码

from spire.xls import * from spire.xls.common import * def list_to_single_column(data_list, output_path, sheet_name="数据"): """将一维列表导出为Excel单列数据""" # 创建工作簿 workbook = Workbook() # 清除默认工作表,新建指定名称的工作表 workbook.Worksheets.Clear() sheet = workbook.Worksheets.Add(sheet_name) # 遍历列表写入单元格,从第1行第1列开始 for index, value in enumerate(data_list): sheet.Range[index + 1, 1].Value = str(value) # 自动调整列宽 sheet.AllocatedRange.AutoFitColumns() # 保存为xlsx格式 workbook.SaveToFile(output_path, ExcelVersion.Version2016) workbook.Dispose() # 调用示例 if name == "main": products = ["笔记本电脑", "机械键盘", "无线鼠标", "27寸显示器", "外接硬盘"] list_to_single_column(products, "single_column.xlsx")

要点说明

  • 行号与列号均从 1 开始计数,这与 Excel 的原生索引方式一致
  • Value属性会自动将输入转为字符串存储,若需保留数值类型可使用NumberValue
  • AutoFitColumns()方法根据内容自动调整列宽,避免内容被截断

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

二维列表(列表嵌套列表)是最接近 Excel 表格结构的数据形式,每一个子列表对应一行数据,通常配合表头使用。

实现思路

  1. 分离表头与数据行,分别写入
  2. 双层循环遍历二维列表,按行列坐标写入单元格
  3. 对表头区域应用基础样式,增强可读性
  4. 批量自适应列宽

完整代码

from spire.xls import * from spire.xls.common import * def list_2d_to_excel(headers, data_rows, output_path, sheet_name="数据表"): """将二维列表导出为带表头的Excel表格""" 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写入,可在 Excel 中参与公式计算;字符串使用Value属性
  • 区域批量操作:通过sheet.Range[行1, 列1, 行2, 列2]获取矩形区域,可一次性设置边框、对齐方式等样式
  • 布尔值处理:直接写入时会显示为 TRUE/FALSE,若需自定义显示文本需转换为字符串

相关新闻

  • 手动降重效果差还费力,有哪些真正值得用的的降AI率软件推荐?
  • iTransformer终极指南:简单快速的时间序列预测深度学习解决方案
  • 基于TI DANCEVM-A评估板的主动降噪耳机开发实战指南

最新新闻

  • Hutool 的 `TimedCache` 到期会自动清理吗? ——————hutool cache的“惰性清理“和“定期清理“
  • ReAct Inside —— 从 Message 到 State,看懂 AI Agent 的工作原理
  • 每日一个开源项目(第145篇):Trellis - 把项目记忆、规范和任务上下文持久化进代码仓库
  • 2026好用的视频去水印工具电脑手机推荐,免费无广告精选
  • 量子约束优化搜索框架CBQS解析与应用
  • 别让AI一直“读心“:冲突触发式心智理论的因果模型

日新闻

  • 【计算机毕业设计案例】基于 Spring Boot+Vue 的电影售票系统设计与实现 前后端分离架构下影院在线购票管理平台(程序+文档+讲解+定制)
  • 到底 TMD 用哪个: npm, pnpm, Yarn, Bun, Deno? 傻瓜, 当然用 npm 啦
  • Google限制Meta使用Gemini模型 凸显AI授权竞争白热化

周新闻

  • Windows字体自定义终极方案:No!! MeiryoUI完全指南
  • Deepin Boot Maker:告别命令行,3分钟制作Linux启动盘的智能解决方案
  • Plain Craft Launcher 2:重新定义你的Minecraft游戏体验

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号