热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用XlsxWriter模块在Python中实现Excel单元格内多种格式文本的高效写入

XlsxWriter是一个强大的Python库,专门用于生成`.xlsx`格式的Excel文件。该模块不仅支持基本的数据写入,还提供了丰富的格式化选项,能够实现单元格内多种文本样式的高效处理。无论是字体、颜色、对齐方式还是边框,XlsxWriter都能轻松应对,满足用户在Excel视图中的各种需求。

XlsxWriter 简介: XlsxWriter 是 python 用来构造 xlsx 后缀 excel 文件的模块,其具备强大的写入功能, 可以说是在 excel 视图中你可以进行的操作都有其对应的实现方法,如富文本写入,控制文本格式,设置列宽等, 然后很重要的一点就是,它不仅仅只是生成数据,还能插入直方图,饼图….(点击此处查看如何插入图),使用条件格式,合并单元格等等这些操作。 附 XlsxWriter 官方文档

需要注意的一点是 XlsxWriter 模块只能写入而不能读取和修改!

接下来通过以下示例主要展示常见的使用方法:

  1. 首先通过 xlsxwriter.Workbook("xlsx_path") 创建一个 workbook 对象,之后可以通过workbook.add_format() 方法先定义需要的样式如下

red = workbook.add_format({"color": "red"}) # 这样我们就有了一个红色样式

其中方法参数是一个字典, 在字典中我们可以给定多个样式如下,RGB颜色参考表(可点击此处查看),其效果可见效果图中 B2 单元格

style = workbook.add_format({
'border': 1, # 边框
'align': 'center', # 水平居中
'valign': 'vcenter', # 垂直居中
'bold': True, # 加粗(默认False)
'font': u'宋体', # 字体
'fg_color': '#FFFF00', # 背景色
'color': 'green' # 字体颜色
})

设置列宽, 函数为 set_column(self, first_col, last_col, :" 分割调用时给定的第一个参数字符串之后解压成这两个参数来指定开始和结束列号(注:前列不能大于后列),调用时第二个参数即 width,可以设定需要将这些列的宽度设为多少, 其效果可见效果图中 B 列

worksheet.set_column("B:B", 30)

设置自动换行格式(可将代码合成一行), 其效果可见效果图中 A 列

column_text_wrap = workbook.add_format()
column_text_wrap.set_text_wrap()

  1. 写入文本及格式

一般的写入方法如下, 其效果可见效果图 A1 单元格

worksheet.write("A1", "段落", bold)

多格式文本写入,将多个定义好的样式整体应用, 其效果可见效果图 B2 单元格

worksheet.write("B2", "陈平安", style)

同一单元格内应用不同格式, 调用时其第一个参数定位其单元格,之后从第二个参数开始两两为一对分别对应 {样式, 文本},即可自定义不同部分的不同样式,其效果可见效果图 A2 单元格

# def write_rich_string(self, row, col, *args):
# """
# Write a "rich" string with multiple formats to a worksheet cell.
#
# Args:
# row: The cell row (zero indexed).
# col: The cell column (zero indexed).
# string_parts: String and format pairs.
# cell_format: Optional Format object.
#
# Returns:
# 0: Success.
# -1: Row or column is out of worksheet bounds.
# -2: String truncated to 32k characters.
# -3: 2 consecutive formats used.
# -4: Empty string used.
# -5: Insufficient parameters.
#
# """
worksheet.write_rich_string("A%d" % 2,
"陈平安是从右到左,住在小茅屋的曹慈则是从左到右。两人视线交汇,双方都无停步的意思,继续各自前行,最终遥遥地擦肩而过。当下,",
red, "陈平安",
"一身拳意极为细微,绝大部分都已经被剑气死死压制。而曹慈一身刚猛拳罡,汹涌外泄,肉眼可见,好像反过来压制了四周的城头剑气。在陈平安一路缓缓走桩,最终临近老剑仙所住茅屋的时候,曹慈已经来回打完一趟拳,赶上了陈平安。")

设置单元格下拉选择框, 调用时第一个参数为单元格位置, 第二个参数为一个字典, 第一个键 validate 需要设为 list, 之后 source 键即为下拉框中的值, 其通过引用表中数据实现(一个单元格一个值), 引用单元格写法为 "$开始列号(字母)$开始行号(数字):$结束列号$结束行号" , 其效果如效果图中 C2 单元格

worksheet.data_validation('C%d' % 2, {'validate': 'list', 'source': "=$F$1:$%s$1" % get_column_letter(len(levels) + 3)}) # get_column_letter 是 openpyxl.utils 工具包中提供的一个提供由数字转为 excel 中列号字母的方法

效果图如下:
《python excel 写入之神器—— XlsxWriter 模块(完美解决同一单元格写入不同格式文本)》
完整代码:

def xlsx_writer_sample(output_path):
workbook = xlsxwriter.Workbook(output_path)
# 设置某个格式
red = workbook.add_format({ "color": "red"})
bold = workbook.add_format({ "bold": True})
# 设置自动换行
column_text_wrap = workbook.add_format()
column_text_wrap.set_text_wrap()
# 自定义格式
style = workbook.add_format({
'border': 1, # 边框
'align': 'center', # 水平居中
'valign': 'vcenter', # 垂直居中
'bold': True, # 加粗(默认False)
'font': u'宋体', # 字体
'fg_color': '#FFFF00', # 背景色
'color': 'green' # 字体颜色
})

# 添加 sheet 并命名
worksheet = workbook.add_worksheet("剑来")

# 设置 A 列宽度及自动换行
worksheet.set_column("A:A", 60, column_text_wrap)
# 设置 B 列宽度
worksheet.set_column("B:B", 30)
# 写入 A1, B1 内容并给定加粗样式
worksheet.write("A1", "段落", bold)
worksheet.write("B1", "主角", bold)
# 从 D1 位置写入多格
levels = ["泥胚境", "木胎境", "水银镜", "炼神三境", "金身境", "远游境", "山巅境", "止境", "武神"]
worksheet.write_row("D1", levels)
# 富文本写入, 对文本某个部分设置格式
worksheet.write_rich_string("A%d" % 2,
"陈平安是从右到左,住在小茅屋的曹慈则是从左到右。两人视线交汇,双方都无停步的意思,继续各自前行,最终遥遥地擦肩而过。当下,",
red, "陈平安",
"一身拳意极为细微,绝大部分都已经被剑气死死压制。而曹慈一身刚猛拳罡,汹涌外泄,肉眼可见,好像反过来压制了四周的城头剑气。在陈平安一路缓缓走桩,最终临近老剑仙所住茅屋的时候,曹慈已经来回打完一趟拳,赶上了陈平安。")
# 为某个单元格写入内容并给定格式, 此格式包含 边框、居中、字体及背景色等
worksheet.write("B2", "陈平安", style)

# 引用下拉选择框
worksheet.data_validation('C%d' % 2, { 'validate': 'list', 'source': "=$F$1:$%s$1" % get_column_letter(len(levels) + 3)})
# 调用 close 方法 结束不报错即成功写入文件
workbook.close()

参考:

  1. Python中XlsxWriter模块简介与用法分析 https://www.jb51.net/article/138813.htm
  2. python模块之XlsxWriter https://www.cnblogs.com/fkissx/p/5617630.html
  3. xlsxwriter基本用法 https://www.jianshu.com/p/e4b8dd083489

推荐阅读
  • Java 9 中 SafeVarargs 注释的使用与示例解析 ... [详细]
  • 成功实现Asp.Net MVC3网站与MongoDB数据库的高效集成
    我们成功地构建了一个基于Asp.NET MVC3框架的网站,并实现了与MongoDB数据库的高效集成。此次更新不仅完善了基本的创建和显示功能,还全面实现了数据的增删改查操作。在创建功能方面,我们修复了之前代码中的错误,确保每个属性都能正确生成。此外,我们还对数据模型进行了优化,以提高系统的性能和稳定性。 ... [详细]
  • Go语言实现Redis客户端与服务器的交互机制深入解析
    在前文对Godis v1.0版本的基础功能进行了详细介绍后,本文将重点探讨如何实现客户端与服务器之间的交互机制。通过具体代码实现,使客户端与服务器能够顺利通信,赋予项目实际运行的能力。本文将详细解析Go语言在实现这一过程中的关键技术和实现细节,帮助读者深入了解Redis客户端与服务器的交互原理。 ... [详细]
  • 在处理大规模并发请求时,传统的多线程或多进程模型往往无法有效解决性能瓶颈问题。尽管它们在处理小规模任务时能提升效率,但在高并发场景下,系统资源的过度消耗和上下文切换的开销会显著降低整体性能。相比之下,Python 的 `asyncio` 模块通过协程提供了一种轻量级且高效的并发解决方案。本文将深入解析 `asyncio` 模块的原理及其在实际应用中的优化技巧,帮助开发者更好地利用协程技术提升程序性能。 ... [详细]
  • 可转债数据智能抓取与分析平台优化
    本项目旨在优化可转债数据的智能抓取与分析平台。通过爬取集思录上的可转债信息(排除已发布赎回的债券),并结合安道全教授提出的三条安全线投资策略,新增了建仓线、加仓线和重仓线,以提供更精准的投资建议。 ... [详细]
  • 2019年后蚂蚁集团与拼多多面试经验详述与深度剖析
    2019年后蚂蚁集团与拼多多面试经验详述与深度剖析 ... [详细]
  • 利用PaddleSharp模块在C#中实现图像文字识别功能测试
    PaddleSharp 是 PaddleInferenceCAPI 的 C# 封装库,适用于 Windows (x64)、NVIDIA GPU 和 Linux (Ubuntu 20.04) 等平台。本文详细介绍了如何使用 PaddleSharp 在 C# 环境中实现图像文字识别功能,并进行了全面的功能测试,验证了其在多种硬件配置下的稳定性和准确性。 ... [详细]
  • 深入解析Spring Boot自动配置机制及其核心原理
    Spring Boot 的自动配置机制是其核心特性之一,旨在简化开发过程并提高效率。本文将深入探讨这一机制的工作原理,解释其如何通过智能化的类路径扫描和条件注解实现自动装配。通过对 Spring Boot 自动配置的详细解析,读者将能够更好地理解和应用这一强大功能,从而在实际项目中更加高效地利用 Spring Boot。 ... [详细]
  • 技术日志:深入探讨Spark Streaming与Spark SQL的融合应用
    技术日志:深入探讨Spark Streaming与Spark SQL的融合应用 ... [详细]
  • 深入解析零拷贝技术(Zerocopy)及其应用优势
    零拷贝技术(Zero-copy)是Netty框架中的一个关键特性,其核心在于减少数据在操作系统内核与用户空间之间的传输次数。通过避免不必要的内存复制操作,零拷贝显著提高了数据传输的效率和性能。本文将深入探讨零拷贝的工作原理及其在实际应用中的优势,包括降低CPU负载、减少内存带宽消耗以及提高系统吞吐量等方面。 ... [详细]
  • MVVM架构~mvc,mvp,mvvm大话开篇
    返回目录百度百科的定义:MVP是从经典的模式MVC演变而来,它们的基本思想有相通的地方:ControllerPresenter负责逻辑的处理,Model提供数据,View负责显示。作为一种新的模 ... [详细]
  • 宏基因组学经典文献重现(一):利用ggplot2进行散点图可视化分析
    宏基因组学经典文献重现(一):利用ggplot2进行散点图可视化分析 ... [详细]
  • JVM参数设置与命令行工具详解
    JVM参数配置与命令行工具的深入解析旨在优化系统性能,通过合理设置JVM参数,确保在高吞吐量的前提下,有效减少垃圾回收(GC)的频率,进而降低系统停顿时间,提升服务的稳定性和响应速度。此外,本文还将详细介绍常用的JVM命令行工具,帮助开发者更好地监控和调优JVM运行状态。 ... [详细]
  • 为了优化直播应用底部聊天框的弹出机制,确保在不同设备上的布局稳定性和兼容性,特别是在配备虚拟按键的设备上,我们对用户交互流程进行了调整。首次打开应用时,需先点击首个输入框以准确获取键盘高度,避免直接点击第二个输入框导致的整体布局挤压问题。此优化通过调整 `activity_main.xml` 布局文件实现,确保了更好的用户体验和界面适配。 ... [详细]
  • 本文深入探讨了 Python Watchdog 库的使用方法和应用场景。通过详细的代码示例,展示了如何利用 Watchdog 监控文件系统的变化,包括文件的创建、修改和删除等操作。文章不仅介绍了 Watchdog 的基本功能,还探讨了其在实际项目中的高级应用,如日志监控和自动化任务触发。读者将能够全面了解 Watchdog 的工作原理及其在不同场景下的应用技巧。 ... [详细]
author-avatar
mobiledu2502855757
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有