[python3]Excel解析库-XlsxWriter

`XlsxWriter` 是一个用于创建 Excel `.xlsx` 文件的 Python 库,它允许你编写程序来生成 Excel 文件,而无需实际运行 Microsoft Excel 应用程序。`XlsxWriter` 支持写入数据、应用格式化、插入图表和图形等多种功能,并且可以处理较大的数据集。它是一个非常流行的选择,尤其是在需要创建复杂的 Excel 报告或进行数据可视化时。

安装

要开始使用 `XlsxWriter`,首先需要安装它。你可以通过 pip 来安装最新版本:

```bash
pip3 install XlsxWriter
```

基本用法

#### 创建一个新的工作簿并添加数据以下是一个简单的例子,演示了如何使用 `XlsxWriter` 创建一个新的 Excel 文件并向其中添加一些数据:```python
import xlsxwriter# 创建一个新的工作簿对象,并添加一个工作表
workbook = xlsxwriter.Workbook('example.xlsx')
worksheet = workbook.add_worksheet()# 写入一些数据到单元格
worksheet.write('A1', 'Hello')  # 单元格位置, 数据
worksheet.write('B1', 'World')# 关闭工作簿(保存文件)
workbook.close()
```#### 设置单元格格式`XlsxWriter` 提供了丰富的格式化选项,包括字体、颜色、对齐方式等。下面是如何应用样式的示例:```python
import xlsxwriter# 创建一个新的工作簿和工作表
workbook = xlsxwriter.Workbook('formatted_example.xlsx')
worksheet = workbook.add_worksheet()# 定义一个样式对象
bold = workbook.add_format({'bold': True})
italic = workbook.add_format({'italic': True})# 使用样式写入数据
worksheet.write('A1', 'Bold Text', bold)
worksheet.write('A2', 'Italic Text', italic)# 关闭工作簿(保存文件)
workbook.close()
```#### 合并单元格你可以合并一行或一列中的多个单元格:```python
import xlsxwriter# 创建一个新的工作簿和工作表
workbook = xlsxwriter.Workbook('merged_cells.xlsx')
worksheet = workbook.add_worksheet()# 写入数据并合并单元格
worksheet.merge_range('A1:B1', 'Merged Cells')  # 第一行, 最后一行, 第一列, 最后一列, 数据# 关闭工作簿(保存文件)
workbook.close()
```#### 添加公式`XlsxWriter` 支持将公式写入 Excel 单元格中:```python
import xlsxwriter# 创建一个新的工作簿和工作表
workbook = xlsxwriter.Workbook('formula_example.xlsx')
worksheet = workbook.add_worksheet()# 写入数值
worksheet.write(0, 0, 1)  # A1
worksheet.write(0, 1, 2)  # B1# 写入公式
worksheet.write_formula(1, 0, '=A1 + B1')  # A2# 关闭工作簿(保存文件)
workbook.close()
```#### 插入图表`XlsxWriter` 支持插入多种类型的图表,如柱状图、折线图等。以下是如何插入柱状图的示例:```python
import xlsxwriter# 创建一个新的工作簿和工作表
workbook = xlsxwriter.Workbook('chart_example.xlsx')
worksheet = workbook.add_worksheet()# 写入一些数据作为图表的数据源
data = [['Category', 'Value'],['A', 10],['B', 40],['C', 50],
]worksheet.write_row('A1', data[0])
worksheet.write_column('A2', data[1][0::2])
worksheet.write_column('B2', data[1][1::2])# 创建一个图表对象
chart = workbook.add_chart({'type': 'column'})# 配置图表系列
chart.add_series({'name':       '=Sheet1!$B$1','categories': '=Sheet1!$A$2:$A$4','values':     '=Sheet1!$B$2:$B$4',
})# 插入图表到工作表中
worksheet.insert_chart('D2', chart)# 关闭工作簿(保存文件)
workbook.close()
```#### 处理日期和时间`XlsxWriter` 可以正确地处理 Python 的 `datetime` 对象,并将它们转换为 Excel 的日期/时间格式:```python
import xlsxwriter
from datetime import datetime# 创建一个新的工作簿和工作表
workbook = xlsxwriter.Workbook('date_time_example.xlsx')
worksheet = workbook.add_worksheet()# 定义日期格式
date_format = workbook.add_format({'num_format': 'yyyy-mm-dd'})# 写入当前日期
worksheet.write_datetime('A1', datetime.now(), date_format)# 关闭工作簿(保存文件)
workbook.close()
```### 更多高级特性- **条件格式**:可以根据单元格内容自动应用不同的格式。
- **数据验证**:可以设置数据有效性规则,例如下拉列表、数字范围限制等。
- **超链接**:支持插入内部或外部的超链接。
- **图片和形状**:可以插入图片、绘制形状等。
- **页眉页脚**:可以自定义打印时的页眉和页脚。
- **页面布局**:可以设置纸张大小、方向、边距等打印属性。### 示例:完整代码示例以下是一个完整的例子,演示了如何使用 `XlsxWriter` 创建包含图表的工作簿,并将其保存到文件系统中:```python
import xlsxwriter
from datetime import datetimedef create_workbook_with_chart():# 创建一个新的工作簿和工作表workbook = xlsxwriter.Workbook('workbook_with_chart.xlsx')worksheet = workbook.add_worksheet()# 写入一些数据作为图表的数据源data = [['Category', 'Value'],['A', 10],['B', 40],['C', 50],]worksheet.write_row('A1', data[0])worksheet.write_column('A2', data[1][0::2])worksheet.write_column('B2', data[1][1::2])# 创建一个图表对象chart = workbook.add_chart({'type': 'column'})# 配置图表系列chart.add_series({'name':       '=Sheet1!$B$1','categories': '=Sheet1!$A$2:$A$4','values':     '=Sheet1!$B$2:$B$4',})# 插入图表到工作表中worksheet.insert_chart('D2', chart)# 写入当前日期date_format = workbook.add_format({'num_format': 'yyyy-mm-dd'})worksheet.write_datetime('A6', datetime.now(), date_format)# 关闭工作簿(保存文件)workbook.close()if __name__ == "__main__":create_workbook_with_chart()

总结

`XlsxWriter` 是一个强大且灵活的库,适用于需要生成 Excel 文件的应用场景。它不仅简化了数据写入的过程,还提供了丰富的格式化和图表功能,使得创建复杂的 Excel 报告变得更加容易。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/65599.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux下部署SSM项目

作者主页&#xff1a;舒克日记 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 Linux部署SSM项目 打包项目 1、修改pom.xml文件&#xff0c;打包方式改为war <packaging>war</packaging>2、idea 通过maven的clean&#xff0c;…

Bytebase 3.0.1 - 可配置在 SQL 编辑器执行 DDL/DML

&#x1f680; 新功能 新增环境策略&#xff0c;允许在 SQL 编辑器内直接执行 DDL/DML 语句。 支持为 BigQuery 数据脱敏。 在项目下新增数据访问控制及脱敏管理页面。 在数据库页面&#xff0c;支持回滚到变更历史的某个版本。 &#x1f514; 兼容性变更 禁止工单创建…

ansible 知识点【回顾梳理】

ansible 知识点 1. 剧本2. facts变量3. register变量4. include功能5. handlers6. when 条件7. with_items 循环8. Jinja2模板9. group_vars10. roles :star::star::star: 看起来字数很多&#xff0c;实际有很多是脚本执行结果&#xff0c;内容不多哦 1. 剧本 剧本很重要的就是…

LLM之RAG实战(五十一)| 使用python和Cypher解析PDF数据,并加载到Neo4j数据库

一、必备条件&#xff1a; python语言Neo4j数据库python库&#xff1a;neo4j、llmsherpa、glob、dotenv 二、代码&#xff1a; from llmsherpa.readers import LayoutPDFReaderfrom neo4j import GraphDatabaseimport uuidimport hashlibimport osimport globfrom datetime …

MLU上使用MagicMind GFPGANv1.4 onnx加速!

文章目录 前言一、平台环境准备二、环境准备1.GFPGAN代码处理2.MagicMind转换修改env.sh修改run.sh参数解析运行 3.修改后模型运行 前言 MagicMind是面向寒武纪MLU的推理加速引擎。MagicMind能将人工智能框架&#xff08;TensorFlow、PyTorch、Caffe与ONNX等&#xff09;训练好…

关于大数据的基础知识(一)——定义特征结构要素

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于大数据的基础知识&#xff08;一&a…

音视频入门基础:MPEG2-PS专题(5)——FFmpeg源码中,解析PS流中的PES流的实现

音视频入门基础&#xff1a;MPEG2-PS专题系列文章&#xff1a; 音视频入门基础&#xff1a;MPEG2-PS专题&#xff08;1&#xff09;——MPEG2-PS官方文档下载 音视频入门基础&#xff1a;MPEG2-PS专题&#xff08;2&#xff09;——使用FFmpeg命令生成ps文件 音视频入门基础…

国标GB28181-2022视频平台EasyGBS小知识:局域网ip地址不够用怎么解决?

在局域网中&#xff0c;IP地址不足的问题通常不会在小型网络中出现&#xff0c;但在拥有超过255台设备的大型局域网中&#xff0c;就需要考虑如何解决IP地址不够用的问题了。 在企业局域网中&#xff0c;经常会出现私有IP地址如192.168.1.x到192.168.1.255不够用的情况。由于0…

spring boot启动源码分析(三)之Environment准备

上一篇《spring-boot启动源码分析&#xff08;二&#xff09;之SpringApplicationRunListener》 环境介绍&#xff1a; spring boot版本&#xff1a;2.7.18 主要starter:spring-boot-starter-web 本篇开始讲启动过程中Environment环境准备&#xff0c;Environment是管理所有…

springmvc前端传参,后端接收

RequestMapping注解 Target({ElementType.METHOD, ElementType.TYPE}) Retention(RetentionPolicy.RUNTIME) Documented Mapping public interface RequestMapping {String name() default "";AliasFor("path")String[] value() default {};AliasFor(&quo…

【Excel/WPS】根据平均值,生成两列/多列指定范围的随机数/随机凑出两列数据

原理就是通过随机生成函数和平均值函数。 适用场景&#xff1a;在总体打分后&#xff0c;需要在小项中随机生成小分数 第一列&#xff1a;固定的平均值A2第二列&#xff1a; RANDBETWEEN(A2-10,A210)第三列&#xff1a;根据第二列用平均值函数算除 A2*2-B2这是随机值1的公式&am…

运动相机拍摄的视频打不开怎么办

3-10 GoPro和大疆DJI运动相机的特点&#xff0c;小巧、高清、续航长、拍摄稳定&#xff0c;很多人会在一些重要场合用来拍摄视频&#xff0c;比如可以用来拿在手里拍摄快速运动中的人等等。 但是毕竟是电子产品&#xff0c;有时候是会出点问题的&#xff0c;比如意外断电、摔重…

智能化文档开发(DI)

这个文档涉及到多模态&#xff08;文本、发票、订单、语音&#xff09; 对于普通的文本&#xff0c;我们希望对某些实体的某些属性挖空生成文档模版&#xff0c;并根据预设字段填空最后生成正式文件对于发票、订单&#xff0c;我们想提取它的字段信息&#xff0c;写入DB对于一些…

【轻松学C:编程小白的大冒险】--- C语言简介 02

在编程的艺术世界里&#xff0c;代码和灵感需要寻找到最佳的交融点&#xff0c;才能打造出令人为之惊叹的作品。而在这座秋知叶i博客的殿堂里&#xff0c;我们将共同追寻这种完美结合&#xff0c;为未来的世界留下属于我们的独特印记。 【轻松学C&#xff1a;编程小白的大冒险】…

零基础 监控数据可视化 Spring Boot 2.x(Actuator + Prometheus + Grafana手把手) (上)

一、安装Prometheus Releases prometheus/prometheus GitHubhttps://github.com/prometheus/prometheus/releases 或 https://prometheus.io/download/https://prometheus.io/download/ 1. 下载适用于 Windows 的二进制文件&#xff1a; 找到最新版本的发布页面&#xf…

Idea日志乱码

问题描述 前提&#xff1a;本人使用windows Idea运行sh文件&#xff0c;指定了utf-8编码&#xff0c;但是运行过程中还是存在中文乱码 Idea的相关配置都已经调整 字体调整为雅黑 文件编码均调整为UTF-8 调整Idea配置文件 但是还是存在乱码&#xff0c;既然Idea相关配置已经…

MySQL 数据表与索引设计艺术:打造高效数据存取架构

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《MySQL技术精粹》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、什么是MySQL 2、MySQL适用场景 二、MySQL的数据存储与检索 1、数据表…

安卓硬件加速hwui

安卓硬件加速 本文基于安卓11。 从 Android 3.0 (API 级别 11) 开始&#xff0c;Android 2D 渲染管道支持硬件加速&#xff0c;这意味着在 View 的画布上执行的所有绘图操作都使用 GPU。由于启用硬件加速所需的资源增加&#xff0c;你的应用程序将消耗更多内存。 软件绘制&am…

海信116英寸RGB-Mini LED:一朵绽放在科技穹顶的中国花火

东方古镇的打铁花&#xff0c;拉斯维加斯的烟花秀&#xff0c;盛大的花火表演总会在岁末年初的时候&#xff0c;吸引世界各地人们的目光。一年一度的科技展会&#xff0c;也起到烟花秀一样的作用&#xff0c;让人们提前望见未知的精彩。 CES还没开始&#xff0c;CES 2025展会的…

积分漏斗模型中5个指标统计

缘起 最近遇到一个积分漏斗模型的设计&#xff0c;这里记录一下。以防止以后忘记了。其中毕竟关键的属性是&#xff1a; 获得积分可用积分已有积分 积分漏斗模型 这里随着【当前日期】也就是今天日期。随着时间一天天过去&#xff0c;积分也一天天过去。上面那个【填报时间】…