[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.rhkb.cn/news/502623.html

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

相关文章

Qt 5.14.2 学习记录 —— 일 新项目

文章目录 1、创建2、查看代码 ---- main.cpp3、查看代码 ---- widgt.h4、查看代码 ---- widgt.cpp和widget.ui5、查看代码 ---- Empty.pro6、运行产生的中间文件 1、创建 左上角的文件,新建文件或项目。如果要写一个GUI程序,应当选择Application&#x…

vscode如何离线安装插件

在没有网络的时候,如果要安装插件,就会麻烦一些,需要通过离线安装的方式进行。下面记录如何在vscode离线安装插件。 一、下载离线插件 在一台能联网的电脑中,下载好离线插件,拷贝到无法联网的电脑上。等待安装。 vscode插件商店地址:https://marketplace.visualstudio.co…

数据仓库中的指标体系模型介绍

数据仓库中的指标体系介绍 文章目录 数据仓库中的指标体系介绍前言什么是指标体系指标体系设计有哪些模型?1. 指标分层模型2. 维度模型3. 指标树模型4. KPI(关键绩效指标)模型5. 主题域模型6.平衡计分卡(BSC)模型7.数据指标框架模…

2025元旦源码免费送

我们常常在当下感到时间慢,觉得未来遥远,但一旦回头看,时间已经悄然流逝。对于未来,尽管如此,也应该保持一种从容的态度,相信未来仍有许多可能性等待着我们。 免费获取源码。 更多内容敬请期待。如有需要可…

2025年Stable Diffusion安装教程(超详细)

StableDiffusion的安装部署其实并不困难,只需简单点击几下,几分钟就能安装好,不管是windows还是苹果mac电脑,关于StableDiffusion的各种安装方式,这片文章一一来给大家讲明白。(所有安装资料都给大家整理好…

【openwrt】OpenWrt 路由器的 802.1X 动态 VLAN

参考链接 [OpenWrt Wiki] Wi-Fi /etc/config/wirelesshttps://openwrt.org/docs/guide-user/network/wifi/basic#wpa_enterprise_access_point 介绍 基于802.1X 无线网络身份验证࿰

Android12 App窗口创建流程

有关的窗口对象 PhoneWindowActivityThread#performLaunchActivity {Activity.attach}Surface new ViewRootImpl 创建null对象 mSurface.transferFrom(getOrCreateBLASTSurface())//填充内容 LayerSurfaceFlinger::createLayerSurfaceControlViewRootImpl#relayoutWindow{mSur…

Leetcode打卡:设计一个ATM机器

执行结果:通过 题目 2241 设计一个ATM机器 一个 ATM 机器,存有 5 种面值的钞票:20 ,50 ,100 ,200 和 500 美元。初始时,ATM 机是空的。用户可以用它存或者取任意数目的钱。 取款时&#xff0c…

在CodeBlocks搭建SDL2工程构建TFT彩屏模拟器虚拟TFT彩屏幕显示

在CodeBlocks搭建SDL2工程构建TFT彩屏模拟器虚拟TFT彩屏幕显示 参考文章源码下载地址一、SDL2的创建、初始化、退出二、系统基本Tick、彩屏刷新、按键事件三、彩屏获取与设置颜色四、彩屏填充颜色及清屏五、彩屏显示中文和英文字符串六、彩屏显示数字七、彩屏初始化八、主函数测…

ESP8266+STM32+阿里云保姆级教程(AT指令+MQTT)

前言:在开发过程中,几乎踩便了所有大坑小坑总结出的文章,我是把坑踩满了,帮助更过小白快速上手,如有错误之处,还麻烦各位大佬帮忙指正、 目录 一、ESP-01s介绍 1、ESP-01s管脚功能: 模组启动模…

美的空气净化器好用吗?拾梧、美的、戴森空气净化器除烟哪个好?

说到二手烟,这可真是个让人头疼的问题!它里面含有超过7000种化学物质,形式多样,处理起来比甲醛这些传统污染物难多了。在市场上那么多空气净化器里,要挑一个能真正对付二手烟的,简直就像大海捞针一样难。不…

【机器学习】穷理至极,观微知著:微积分的哲思之旅与算法之道

文章目录 微积分基础:理解变化与累积的数学前言一、多重积分的高级应用1.1 高维概率分布的期望值计算1.1.1 多维期望值的定义1.1.2 Python代码实现1.1.3 运行结果1.1.4 结果解读 1.2 特征空间的体积计算1.2.1 单位球体的体积计算1.2.2 Python代码实现1.2.3 运行结果…

Ae:合成设置 - 3D 渲染器

Ae菜单:合成/合成设置 Composition/Composition Settings 快捷键:Ctrl K After Effects “合成设置”对话框中的3D 渲染器 3D Renderer选项卡用于选择和配置合成的 3D 渲染器类型,所选渲染器决定了合成中的 3D 图层可以使用的功能&#xff0…

Zookeeper是如何解决脑裂问题的?

大家好,我是锋哥。今天分享关于【Zookeeper是如何解决脑裂问题的?】面试题。希望对大家有帮助; Zookeeper是如何解决脑裂问题的? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Zookeeper 通过一系列的机制来防止和解决脑裂(sp…

【python因果库实战15】因果生存分析4

这里写目录标题 加权标准化生存分析总结个体层面的生存曲线 加权标准化生存分析 我们还可以将加权与标准化结合起来,使用 WeightedStandardizedSurvival 模块。在这里,我们将逆倾向得分加权模型(根据基线协变量重新加权人群)与加…

windows中硬件加速gpu计划开启cpu的使用率居高不下

1.加速gpu计划开启在任务管理器的gpu选项中看不到cuda选项,这给我们进行深度学习训练和推理带来很大影响。 2.开启硬件加速CPU的占用率明显增高,特别用GPU进行实时视频流解码时就不会分配给GPU解码,造成cpu占用居高不下。不利于深度学习训练…

OpenGL入门最后一章观察矩阵(照相机)

前面的一篇文章笔者向大家介绍了模型变化矩阵,投影矩阵。现在只剩下最后一个观察矩阵没有和大家讲了。此片文章就为大家介绍OpenGL入门篇的最后一个内容。 观察矩阵 前面的篇章当中,我们看到了即使没有观察矩阵,我们也能对绘制出来的模型有一…

java.lang.Error: FFmpegKit failed to start on brand:

如果你使用FFmpegKit的时候遇到了这个问题: java.lang.Error: FFmpegKit failed to start on brand: Xiaomi, model: MI 8, device: dipper, api level: 29, abis: arm64-v8a armeabi-v7a armeabi, 32bit abis: armeabi-v7a armeabi, 64bit abis: arm64-v8a.at c…

KAGGLE竞赛实战2-捷信金融违约预测竞赛-part1-数据探索及baseline建立

竞赛链接:https://www.kaggle.com/competitions/home-credit-default-risk/ 认识数据集:application的两张表是申请人信息 通过id关联bureau:过去的借款、previous_application两张表 而bureau_balance则代表对应的还款信息 表之间的关系…

【软考网工笔记】计算机基础理论与安全——网络安全

病毒 Melissa 宏病毒 1. 是一种快速传播的能够感染那些使用MS Word 97 和MS Office 2000 的计算机宏病毒。 2. 前面有**Macro** 表示这是宏病毒; 3. 宏病毒可以感染后缀为.xls的文件;Worm 蠕虫病毒 1. 通常是通过网络或者系统漏洞进行传播。 2. 利用信…