[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 datetime

def 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 报告变得更加容易。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习中CUDA环境安装教程

首先说明,本人是小白,一次安装,可能有不对的地方,望包含。 安装CUDA 因为我们是深度学习,很多时候要用到gpu进行训练,所以我们需要一种方式加快训练速度。 通俗地说,CUDA是一种协助“CPU任务分…

基于word2vec的推荐系统

基于word2vec的推荐系统 可用于推荐商品,图书,电影,课程,旅游景点,音乐… 效果 网址点我跳转 一、word2vec简介 Word2Vec是一种词向量表示方法,是在自然语言处理领域(NLP)的神经…

多目标优化算法——基于聚类的不规则Pareto前沿多目标优化自适应进化算法(CA-MOEA)

基于聚类的不规则Pareto前沿多目标优化自适应进化算法(CA-MOEA) 一、算法简介 简介: 现有的多目标进化算法(moea)在具有规则Pareto前沿且Pareto最优解在目标空间上连续分布的多目标优化问题(MOPs&#xff…

Kubernetes开发环境minikube | 开发部署apache tomcat web单节点应用

minikube是一个主要用于开发与测试Kubernetes应用的运行环境 本文主要描述在minikube运行环境中部署J2EE tomcat web应用 minikube start --force minikube status 如上所示,在Linux中启动minikube运行环境 service docker start docker version service docker …

【QT-QTableView实现鼠标悬浮(hover)行高亮显示+并设置表格样式】

1、自定义委托类 HoverDelegate hoverdelegate.h #ifndef HOVERDELEGATE_H #define HOVERDELEGATE_H#include <QObject> #include <QStyledItemDelegate>class hoverdelegate : public QStyledItemDelegate {Q_OBJECT // 添加 Q_OBJECT 宏public:explicit hoverde…

企业网络性能监控

什么是网络性能监控 网络性能监控&#xff08;NPM&#xff09;是指对计算机网络的性能进行持续测量、分析和管理的过程&#xff0c;通过监控流量、延迟、数据包丢失、带宽利用率和正常运行时间等关键指标&#xff0c;确保网络高效、安全地运行&#xff0c;并将停机时间降至最低…

引领AI发展潮流:打造大模型时代的安全与可信——CCF-CV企业交流会走进合合信息会议回顾

一、前言 随着数字化浪潮的推动&#xff0c;人工智能技术正在以前所未有的速度深刻改变着我们的生活、工作方式以及社会结构。AI技术的飞速发展不仅为各行业带来了前所未有的机遇&#xff0c;也同时引发了关于其风险与挑战的广泛关注。如何平衡技术进步与安全保障&#xff0c;…

List ---- 模拟实现LIST功能的发现

目录 listlist概念 list 中的迭代器list迭代器知识const迭代器写法list访问自定义类型 附录代码 list list概念 list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。list的底层是双向链表结构&#xff0c;双向链表中每个元素…

Matlab回归预测大合集(不定期更新)-188

截至2025-1-2更新 1.BP神经网络多元回归预测&#xff08;多输入单输出&#xff09; 2.RBF神经网络多元回归预测&#xff08;多输入单输出&#xff09; 3.RF随机森林多元回归预测&#xff08;多输入单输出&#xff09; 4.CNN卷积神经网络多元回归预测&#xff08;多输入单输…

go语言zero框架中教务crm系统的在职继承和离职交接的设计与实践

在GoZero中实现一个在职继承和离职交接的通用模块&#xff0c;涉及到顾问离职交接客户、领导离职交接审批单据等功能。为了使这个模块通用且易于扩展&#xff0c;我们可以分成几个部分&#xff1a; 1. **数据模型设计**&#xff1a;我们首先需要设计离职交接相关的数据模型。 …

Mac软件介绍之录屏软件Filmage Screen

软件介绍 Filmage Screen 是一款专业的视频录制和编辑软件&#xff0c;适用于 Mac 系统 可以选择4k 60fps&#xff0c;可以选择录制电脑屏幕&#xff0c;摄像头录制&#xff0c;可以选择区域录制。同时也支持&#xff0c;简单的视频剪辑。 可以同时录制电脑麦克风声音 标准…

毕业项目推荐:基于yolov8/yolov5的行人检测识别系统(python+卷积神经网络)

文章目录 概要一、整体资源介绍技术要点功能展示&#xff1a;功能1 支持单张图片识别功能2 支持遍历文件夹识别功能3 支持识别视频文件功能4 支持摄像头识别功能5 支持结果文件导出&#xff08;xls格式&#xff09;功能6 支持切换检测到的目标查看 二、数据集三、算法介绍1. YO…

对话|企业如何构建更完善的容器供应链安全防护体系

对话&#xff5c;企业如何构建更完善的容器供应链安全防护体系 云布道师 随着云计算和 DevOps 的兴起&#xff0c;容器技术和自动化成为软件开发中的必要手段&#xff0c;软件供应链也进入了自动化及 CI/CD 阶段。然而&#xff0c;容器技术和自动化虽然提升了软件的更新速度&…

小试牛刀-SpringBoot集成SOL链

目录 一、什么是solanaj? 二、Pom依赖 三、主要类 3.1 RpcClient 3.2 PublicKey 3.3 Transaction 3.4 TransactionInstruction 四、示例代码 Welcome to Code Blocks blog 本篇文章主要介绍了 [小试牛刀-SpringBoot集成SOL链] ❤博主广交技术好友&#xff0c;喜欢文章的…

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 …

牛客网刷题 ——C语言初阶(5操作符)——BC117 小乐乐走台阶

1.题目 &#xff1a;BC117 小乐乐走台阶 牛客OJ题链接 描述 小乐乐上课需要走n阶台阶&#xff0c;因为他腿比较长&#xff0c;所以每次可以选择走一阶或者走两阶&#xff0c;那么他一共有多少种走法&#xff1f; 输入描述&#xff1a; 输入包含一个整数n (1 ≤ n ≤ 30) …

gitlab高级功能之 CICD Steps

CICD Steps 1. 介绍2. 定义 Steps2.1 Inputs2.2 Outputs 3. Using steps3.1 Set environment variables3.2 Running steps locally 4. Scripts5. Actions5.1 已知的问题 6. 表达式7. 实操7.1 单个step7.2 多个step7.3 复用steps7.4 添加output到step7.5 使用远程step 1. 介绍 …

【Unity3D】UGUI Canvas画布渲染流程

目录 Screen Space - Overlay Screen Space - Camera World Space UI合批分析&#xff08;建议不看 直接看FrameDebugger测试&#xff09; 优化UI合批 1、Image图片纹理不同导致合批失败 2、文本和图片相交以及排序对合批的影响 3、Mask对合批的影响&#xff08;情况…

平安产险安徽分公司携手安徽中医药临床研究中心附属医院 共筑儿童安全防护网

为响应金融知识普及教育号召&#xff0c;平安产险安徽分公司联动安徽中医药临床研究中心附属医院&#xff0c;于近日在朝霞小学举办了一场儿童安全防范与健康守护活动。此次活动旨在提升学生的安全防范意识&#xff0c;守护儿童健康成长&#xff0c;同时有力推动金融知识与传统…

zephyr移植到STM32

Zephy如何移植到单片机 1. Window下搭建开发环境1.1 安装Choncolatey1.2 安装相关依赖1.3创建虚拟python环境1.4 安装west1.4.1 使用 pip 安装 west1.4.2 检查 west 安装路径1.4.3 将 Scripts路径添加到环境变量1.4.4 验证安装 1.5 获取zephyr源码和[安装python](https://so.cs…