热门标签 | 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

推荐阅读
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • Python第三方库安装的多种途径及注意事项
    本文详细介绍了Python第三方库的几种常见安装方法,包括使用pip命令、集成开发环境(如Anaconda)以及手动文件安装,并提供了每种方法的具体操作步骤和适用场景。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • 解决FCKeditor应用主题后上传问题及优化配置
    本文介绍了在Freetextbox收费后选择FCKeditor作为替代方案时遇到的上传问题及其解决方案。通过调整配置文件和调试工具,最终解决了上传失败的问题,并对相关配置进行了优化。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
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社区 版权所有