翼度科技»论坛 编程开发 python 查看内容

使用 Python 将数据写入 Excel 工作表

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
在数据处理和报告生成等工作中,Excel 表格是一种常见且广泛使用的工具。然而,手动将大量数据输入到 Excel 表格中既费时又容易出错。为了提高效率并减少错误,使用 Python 编程语言来自动化数据写入 Excel 表格是一个明智的选择。Python 作为一种简单易学且功能强大的编程语言,其丰富的模块能够处理各种任务,包括操作 Excel 文件。通过编写 Python 代码,您可以轻松地将数据写入 Excel 表格,无论是小规模的数据集还是大规模的数据处理,使用 Python 自动化数据写入过程都可以大大提高工作效率,减少人为错误的发生。
本文中将介绍如何使用 Python 写入数据到 Excel 表格,提供更高效和准确的 Excel 表格数据写入方案,从而简化数据处理流程并节省宝贵的时间和精力。本文主要包含以下几个方面:

  • Excel 数据写入相关介绍
  • 通过 Python 写入文本或数值到 Excel 单元格
  • 通过 Python 写入数组到 Excel 工作表
  • 通过 Python 写入 CSV 数据到 Excel 工作表
  • 通过 Python 写入 XML 数据到 Excel 工作表
本文所使用的方法需要用到 Spire.XLS for Python,可从官网下载或通过 PyPI 安装:
  1. pip install Spire.XLS
复制代码
 

Excel 数据写入相关介绍


  • 本文所使用的 API 中,使用 Workbook 类来代表一个 Excel 工作簿。在操作 Excel 工作簿时,可以使用该类下的 LoadFromFile() 方法从文件读取 Excel 工作簿进行操作或直接通过创建 Workbook 的对象从而创建工作簿进行操作。需要注意的是,新建的 Excel 工作簿默认有三个工作表。
  • 同时,该 API 还提供 Worksheet 类和一系列方法、属性来对工作表及其中的单元格数据、格式等内容进行操作。
  • 表格数据的主要来源有 CSV 文件、文本、数组、XML 文件等。当我们需要制作报告等方便查看和分析的表格时,通过程序将这些类型的表格数据写入到 Excel 表格中可以实现高效精确的表格生成。
  • Worksheet.Range[str] 属性用于获取指定单元格或指定单元格范围。其中,单元格和单元格范围的表示方法与 Excel 相同,即 “字母 + 数字” 表示单元格,“字母 + 数字:字母 + 数字” 表示单元格范围,如 “A1” 和 “A1:C3”。
  • Workbook.SaveToFile(str, FileFormat) 方法用于保存 Excel 工作簿到文件,可将 FileFormat 枚举类型作为参数设置保存的文件格式。
 

通过 Python 写入文本或数字数据到 Excel 单元格

使用 Workbook 类直接创建 Excel 工作簿或载入工作簿之后,可以使用该类下的方法设置格式及写入数据。以下是写入文本或数值到 Excel 单元格操作示例:

  • 导入所需模块。
  • 创建 Workbook 类的对象以创建 Excel 工作簿。
  • 使用 Workbook.Worksheets.Clear() 方法删除默认的工作表,并使用 Workbook.Worksheets.Add() 方法新建一个工作表。
  • 通过 Worksheet 类下的属性设置单元格格式。
  • 通过 Worksheet.Range[].Text 属性添加文本或数值到指定单元格。
  • 使用 Workbook.SaveToFile() 方法保存工作簿到文件并关闭工作簿。
代码示例:
  1. from spire.xls import Workbook
  2. from spire.xls import Worksheet
  3. from spire.xls import FileFormat
  4. # 创建Excel工作簿
  5. workbook = Workbook()
  6. # 删除工作表并创建新的工作表
  7. workbook.Worksheets.Clear()
  8. worksheet = workbook.Worksheets.Add("成员信息")
  9. # 设置单元格格式
  10. worksheet.Range["A1:D1"].Style.Font.IsBold = True
  11. worksheet.Rows[0].RowHeight = 30
  12. worksheet.Range["A1:D1"].Style.Font.Size = 12
  13. worksheet.Range["A2:D4"].Style.Font.Size = 11
  14. # 写入表头数据
  15. worksheet.Range["A1"].Text = "序号"
  16. worksheet.Range["B1"].Text = "姓名"
  17. worksheet.Range["C1"].Text = "年龄"
  18. worksheet.Range["D1"].Text = "职业"
  19. # 写入其他数据
  20. worksheet.Range["A2"].Text = "1"
  21. worksheet.Range["A3"].Text = "2"
  22. worksheet.Range["A4"].Text = "3"
  23. worksheet.Range["B2"].Text = "约翰"
  24. worksheet.Range["B3"].Text = "乔伊"
  25. worksheet.Range["B4"].Text = "迈克"
  26. worksheet.Range["C2"].Text = "35"
  27. worksheet.Range["C3"].Text = "28"
  28. worksheet.Range["C4"].Text = "42"
  29. worksheet.Range["D2"].Text = "工程师"
  30. worksheet.Range["D3"].Text = "律师"
  31. worksheet.Range["D4"].Text = "医生"
  32. # 保存工作簿
  33. workbook.SaveToFile("output/写入数据到单元格.xlsx", FileFormat.Version2016)
  34. workbook.Dispose()
复制代码
输出的 Excel 工作簿:

 
通过 Python 写入数组到 Excel 工作表

使用 Worksheet.InsertArray(arrObject: List[], firstRow: int, firstColumn: int, isVertical: bool) 方法可以插入数组到 Excel 工作表中,同时可设置插入的位置及方式。以下是操作步骤介绍:

  • 导入所需模块。
  • 创建 Workbook 对象以创建 Excel 工作簿。
  • 使用 Workbook.Worksheets.Clear() 方法清除默认的工作表,并使用 Workbook.Worksheets.Add() 方法新建一个名为 "销售数据" 的工作表。
  • 使用 Worksheet 类下的属性设置单元格格式。
  • 创建一个二维数组 tableArray,其中包含要插入到工作表的数据。
  • 遍历二位数组的每一个列表,使用 Worksheet.InsertArray() 方法将列表中的数据插入到工作表的指定单元格中。
  • 使用 Workbook.SaveToFile() 方法将工作簿保存到指定的文件中并关闭工作簿。
代码示例:
  1. from spire.xls import Workbook
  2. from spire.xls import FileFormat
  3. # 创建Excel工作簿
  4. workbook = Workbook()
  5. # 清除默认工作表并新建工作表
  6. workbook.Worksheets.Clear()
  7. worksheet = workbook.Worksheets.Add("销售数据")
  8. # 设置单元格格式
  9. worksheet.Range["A1:D1"].Style.Font.IsBold = True
  10. worksheet.Rows[0].RowHeight = 30
  11. worksheet.Range["A1:D1"].Style.Font.Size = 12
  12. worksheet.Range["A2:D4"].Style.Font.Size = 11
  13. # 数组
  14. tableArray = [
  15.     ["日期", "产品", "销售额"],
  16.     ["20220101", "产品A", "1000"],
  17.     ["20220101", "产品B", "1500"],
  18.     ["20220102", "产品A", "1200"],
  19.     ["20220102", "产品B", "1800"],
  20.     ["20220103", "产品A", "900"],
  21.     ["20220103", "产品B", "1600"]
  22. ]
  23. # 将数据逐行插入工作表
  24. i = 1
  25. for array in tableArray:
  26.     worksheet.InsertArray(array, i, 1, False)
  27. # 保存工作簿
  28. workbook.SaveToFile("output/写入数组到工作表.xlsx", FileFormat.Version2016)
  29. workbook.Dispose()
复制代码
输出的 Excel 工作簿:

 
通过 Python 写入 CSV 数据到 Excel 工作表

在将 CSV 数据写入 Excel 表格时,我们可以直接使用 Workbook.LoadFromFile () 方法载入 CSV 文件并保存为 XLSX 格式,从而将 CSV 文件直接转换为 Excel 工作簿。再载入 CSV 文件时,可通过分隔符作为参数来载入不同分隔符的 CSV 表格。以下是操作示例:

  • 导入所需模块。
  • 创建 Workbook 类的对象。
  • 使用 Workbook.LoadFromFile() 方法载入 CSV 文件。
  • 使用 Workbook.SaveToFile() 方法将 CSV 文件保存为 Excel 工作簿。
代码示例:
  1. from spire.xls import Workbook
  2. from spire.xls import FileFormat
  3. # 创建Workbook类的对象
  4. workbook = Workbook()
  5. # 载入CSV文件
  6. workbook.LoadFromFile("销量统计.csv", ",")
  7. # 保存为Excel工作簿
  8. workbook.SaveToFile("output/写入CSV数据到工作表.xlsx", FileFormat.Version2016)
  9. workbook.Dispose()
复制代码
保存结果: 

 
通过 Python 写入 XML 数据到 Excel 工作表

写入 XML 数据到 Excel 工作表需要读取 XML 数据,然后先将表头写入工作表,然后再写入对应数据到单元格中。需要根据 XML 表格数据的结构调整代码进行写入。 下面是操作步骤介绍:

  • 导入模块。
  • 创建一个 Workbook 类的对象。
  • 清除默认工作表并使用 Workbook.Worksheets.Add(str Name) 方法添加一个工作表。
  • 设置工作表的单元格格式。
  • 加载 XML 数据,使用 xml.etree.ElementTree 模块的 parse 方法解析 XML 文件,获取根元素和子元素。
  • 获取第一个 student 节点来确定列数和表头。
  • 写入表头,通过迭代表头节点并将其作为列标题写入工作表。
  • 写入数据,通过迭代每个学生节点和对应的数据节点,使用 Worksheet.SetValue(int rowIndex, int columnIndex, str Valuw) 将数据值写入工作表。
  • 使用 SaveToFile 方法将工作簿保存为指定路径的 Excel 文件并释放资源。
代码示例:
  1. from spire.xls import *
  2. from spire.common import *
  3. import xml.etree.ElementTree as ET
  4. # 创建一个Workbook类的对象
  5. workbook = Workbook()
  6. # 清除默认工作表并添加一个工作表
  7. workbook.Worksheets.Clear()
  8. worksheet = workbook.Worksheets.Add("学生信息")
  9. # 设置单元格格式
  10. for i in range(len(worksheet.Columns)):
  11.     col = worksheet.Columns.get_Item(i)
  12.     col.ColumnWidth = 10
  13. # 加载 XML 数据
  14. xml_tree = ET.parse("学生信息.xml")
  15. xml_root = xml_tree.getroot()
  16. # 获取第一个order节点来确定列数和表头
  17. first_student = xml_root.find("student")
  18. header = list(first_student.iter())[1:]  # 跳过第一个节点
  19. # 写入表头
  20. for col_index, header_node in enumerate(header, start=1):
  21.     header_text = header_node.tag
  22.     worksheet.SetValue(1, col_index, header_text)
  23. # 写入数据
  24. row_index = 2
  25. for student in xml_root.iter("student"):
  26.     for col_index, data_node in enumerate(list(student.iter())[1:], start=1):  # 跳过第一个节点
  27.         value = data_node.text
  28.         header_text = list(header[col_index - 1].iter())[0].tag
  29.         worksheet.SetValue(row_index, col_index, value)
  30.     row_index += 1
  31. # 保存工作簿为新的 Excel 文件
  32. workbook.SaveToFile("output/写入XML到工作表.xlsx")
  33. workbook.Dispose()
复制代码
部分 XML 数据:
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <students>
  3.   <student>
  4.     <id>1</id>
  5.     <name>John Doe</name>
  6.     <major>Data Science</major>
  7.     <gpa>3.8</gpa>
  8.     <age>20</age>
  9.     <gender>Male</gender>
  10.     <contact>
  11.       <email>john.doe@example.com</email>
  12.       <phone>123-456-7890</phone>
  13.     </contact>
  14.   </student>
复制代码
输出的 Excel 工作簿:

 
总结:本文介绍了如何使用 Python 将各种数据保存为 Excel 表格,包括文本、数组、XML、CSV 等。通过 Python 代码,我们可以轻松地保存各种数据到 Excel 工作表中,实现批量操作,快速生成视觉友好地电子表格。Spire.XLS for Python 还支持许多其他功能,可前往 Spire.XLS for Python 教程查看。
 

来源:https://www.cnblogs.com/Yesi/p/17964783
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具