Python操作合并单元格

news2025/1/3 1:05:11

如何使用python操作Excel实现对合并单元格的一系列操作

01、准备工作(使用镜像下载)

pip install openpyx -i https://pypi.tuna.tsinghua.edu.cn/simple

02、简单示例

简单创建一个工作簿进行示范:

from openpyxl import Workbook
from openpyxl.utils import get_column_letter, column_index_from_string
from openpyxl.styles import Alignment

# 创建一个新的工作簿
wb = Workbook()
ws = wb.active

# 合并A1到C3的单元格
start_cell = 'A1'
end_cell = 'F8'

# 写入数据到合并的单元格
ws[start_cell] = '合并后的数据'

# 获取起始单元格的行索引和列索引
start_row = int(start_cell[1:])
start_col = column_index_from_string(start_cell[0])

# 获取结束单元格的行索引和列索引
end_row = int(end_cell[1:])
end_col = column_index_from_string(end_cell[0])

# 设置合并单元格的样式
merge_range = f'{get_column_letter(start_col)}{start_row}:{get_column_letter(end_col)}{end_row}'
ws.merge_cells(merge_range)

# 针对每个合并的单元格应用对齐样式
for row in ws[merge_range]:
    for cell in row:
        cell.alignment = Alignment(horizontal='center', vertical='center')

# 保存工作簿到文件
wb.save('merged_data.xlsx')

运行后的结果如下:
在这里插入图片描述

03、简单分析一下上述操作的底层原理

openpyxl是一个用于读取和写入Excel文件的Python库。它使用了底层的XML解析和生成技术来实现对Excel文件的操作。

​ 在底层,openpyxl库将Excel文件视为一系列的XML文件。每个Excel文件都由多个XML文件组成,其中包含了工作簿、工作表、单元格、样式等信息。

​ 当使用openpyxl库读取Excel文件时,它会解析这些XML文件,提取出工作簿、工作表和单元格的数据,并将其转换为Python对象进行处理。例如,openpyxl将工作簿表示为一个Workbook对象,工作表表示为一个Worksheet对象,单元格表示为一个Cell对象。你可以通过这些对象来访问和修改Excel文件的内容。

​ 当使用openpyxl库写入Excel文件时,它会根据你提供的数据和操作,生成适当的XML文件,并将其写入到Excel文件中。例如,当你调用ws['A1'] = 'Hello'时,openpyxl会生成一个包含<c><v>标签的XML片段,表示在A1单元格中设置了值为’Hello’。然后,openpyxl会将这个XML片段插入到相应的位置,更新Excel文件。

​ 总结来说,openpyxl库的底层原理是通过解析和生成Excel文件的XML来实现对Excel文件的读取和写入。它提供了方便的高级操作接口,使得我们可以更简单地处理Excel文件的内容和样式。

04、进阶版操作excel的合并单元格

首先完成对合并单元格的拆分操作,以下给出源文件和示例代码:

  • 以下是待处理文件
    在这里插入图片描述

  • 以下是示例代码:

    from openpyxl import load_workbook
    
    # 加载 Excel 文件
    workbook = load_workbook('KIC01.xlsx')
    sheet = workbook.active
    merged_cells = sheet.merged_cells.ranges
    
    # 创建临时的合并单元格列表
    merged_cells_to_remove = []
    
    # 找出所有的合并单元格
    for merged_cell_range in merged_cells:
        min_row, min_col, max_row, max_col = merged_cell_range.min_row, merged_cell_range.min_col, merged_cell_range.max_row, merged_cell_range.max_col
        for row in range(min_row, max_row + 1):
            for col in range(min_col, max_col + 1):
                if (row, col) != (min_row, min_col):
                    merged_cells_to_remove.append(merged_cell_range)
    
    # 遍历临时的合并单元格列表并解除合并
    for merged_cell_range in merged_cells_to_remove:
        try:
            sheet.unmerge_cells(str(merged_cell_range))
        except ValueError:
            pass
    
    # 保存修改后的 Excel 文件
    workbook.save('output.xlsx')
    
  • 以下是操作后的结果:
    在这里插入图片描述

05、指定条件下对单元格进行数据合并

操作excel表格,对于符合特定要求的单元格进行合并单元格操作,以下为具体步骤:

  • 待处理文件
    在这里插入图片描述

  • 以下是示例代码:

    from openpyxl import load_workbook
    from openpyxl.utils import get_column_letter
    
    # 加载 Excel 文件
    workbook = load_workbook('KIC.xlsx')
    sheet = workbook.active
    
    # 定义要遍历的列以及从第几行开始遍历
    column_to_merge = 'A'
    start_row = 4
    
    # 获取该列的最大行数
    max_row = sheet.max_row
    
    # 遍历该列并合并单元格
    for row in range(start_row, max_row + 1, 3):
        # 计算当前要合并的单元格范围
        merge_range = f'{column_to_merge}{row}:{column_to_merge}{row+2}'
        # 将单元格合并
        sheet.merge_cells(merge_range)
    
    # 将修改后的 Excel 文件保存到磁盘
    workbook.save('output.xlsx')
    
  • 以下是处理后的文件

在这里插入图片描述

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

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

相关文章

数学建模 | MATLAB数据建模方法--机器学习方法

近年来&#xff0c;全国赛的题目中&#xff0c;多多少少都有些数据&#xff0c;而且数据量总体来说呈不断增加的趋势&#xff0c; 这是由于在科研界和工业界已积累了比较丰富的数据&#xff0c;伴随大数据概念的兴起及机器学习技术的发展&#xff0c; 这些数据需要转化成更有意…

利用 FormData 实现文件上传、监控网路速度和上传进度

利用 FormData 实现文件上传 基础功能&#xff1a;上传文件 演示如下&#xff1a; 概括流程&#xff1a; 前端&#xff1a;把文件数据获取并 append 到 FormData 对象中后端&#xff1a;通过 ctx.request.files 对象拿到二进制数据&#xff0c;获得 node 暂存的文件路径 前端…

推荐3个完美替代 Navicat 的工具

现在企业&#xff0c;mysql数据库用的比较多&#xff0c;mysql数据库客户端的需求也就比较大&#xff0c;navicat就被大家所熟知。 这个工具&#xff0c;确实好用&#xff0c;功能也非常强大&#xff0c;但是&#xff0c;它的强大&#xff0c;是需要付费&#xff0c;或者用一些…

Ubuntu 2204 安装libimobiledevice

libimobiledevice是一个开源的软件&#xff0c;它可以直接使用系统原生协议和IOS设备进行通信&#xff0c;类似iMazing&#xff0c;iTunes&#xff0c;libimobiledevice不依赖IOS的私有库&#xff0c;并且连接IOS设备时用的都是原生协议&#xff0c;IOS无需越狱就能实现设备信息…

css实现简单的抽奖动画效果

使用css的animation和transform和transition可以实现简单的图片放大缩小&#xff0c;旋转&#xff0c;位移的效果&#xff0c;由此可以延伸的动画效果还是挺多的&#xff0c;比如图片慢慢放大&#xff0c;图片慢慢旋转并放大&#xff0c;图片慢慢变化位置等等&#xff0c; 抽奖…

TCP三次握手过程

什么是TCP tcp是一个面向连接的、可靠的、基于字节流的传输层通信协议 面向连接&#xff1a;TCP连接是一对一的&#xff0c;不能实现一对多或多对一&#xff0c;TCP在通信前要首先建立连接&#xff0c;连接成功后才能开始进行通信可靠的&#xff1a;TCP连接要保证通信过程的可靠…

HUAWEI Vision Pro?华为欲出手竞品对标Apple Vision Pro

大家好&#xff0c;我是极智视界&#xff0c;欢迎关注我的公众号&#xff0c;获取我的更多前沿科技分享 邀您加入我的知识星球「极智视界」&#xff0c;星球内有超多好玩的项目实战源码和资源下载&#xff0c;链接&#xff1a;https://t.zsxq.com/0aiNxERDq Apple Vision Pro 是…

【Python】永久切换pip下载源

目录 永久切换pip下载源切换方式pip国内镜像源参考 永久切换pip下载源 使用Python默认pip下载源容易导致部分库下载超时失败&#xff0c;将pip下载源切换回国内&#xff0c;避免超时访问导致失败 切换方式 通过修改配置文件完成切换&#xff1a; 进入到 C:\Users\用户名 路径…

Python批量Git Pull,对文件夹批量进行Pull操作

效果展示 说明 本来是想写的完善一些&#xff0c;但由于是自用&#xff0c;所以写出来后发现已经解决了自己的问题&#xff0c;所有 2和3功能没有写。 执行的话&#xff0c;需要 cmd 之后 直接 Python BatchGitPull.py 运行下面代码即可。 里面同时涉及到其他Pyhon知识点(写给…

无桌面版docker在Ubuntu系统上安装

目录 注意 系统要求 卸载旧版本 安装 使用apt存储库安装 1. 设置 Docker 的apt存储库。 2. 安装Docker软件包 3. 通过运行镜像来验证Docker Engine安装是否成功 hello-world。 从包中安装 1. 进入 https://download.docker.com/linux/ubuntu/dists/。 2. 在列表中选择…

2023最新软件测试八股文,你背得怎样了

今天给大家分享软件测试面试题基础篇&#xff0c;看看大家能答对几题 1、软件测试方法有哪些分类?各自有什么特点?设计测试用例的主要方法有哪些? 白盒: 测试人员利用程序内部的逻辑结构及相关信息&#xff0c;设计或选择型试用例:对程序所有的逻辑路径进行测试。 黑盒: …

用Flask构建Python的API接口

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版&#xff0c;欢迎购买。点击进入详情 文章目录 Flask简介编码运行 Flask简介 如果你的代码是用python实现的&#xff0c;但是你想写一个类似SpringBoot那种的API接口&#xff0c;这时我们可以使用Flas…

算法基础四

括号生成 数字 n 代表生成括号的对数&#xff0c;请你设计一个函数&#xff0c;用于能够生成所有可能的并且 有效的 括号组合。 示例 1&#xff1a; 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;[“((()))”,“(()())”,“(())()”,“()(())”,“()()()”] 示例…

io基础入门

压缩的封装 参考&#xff1a;https://blog.csdn.net/qq_29897369/article/details/120407125?utm_mediumdistribute.pc_relevant.none-task-blog-2defaultbaidujs_baidulandingword~default-0-120407125-blog-120163063.235v38pc_relevant_sort_base3&spm1001.2101.3001.…

05-建造者模式-C语言实现

UML类图&#xff1a; 代码实现&#xff1a; #include <stdio.h> #include <stdlib.h>// 产品类 typedef struct {char* part1;char* part2;char* part3; } Product;// 抽象建造者类 typedef struct {void (*buildPart1)(void*, const char*);void (*buildPart2)(v…

【广州华锐视点】广东3D展厅开发服务找广州华锐视点,打造未来展览新体验!

随着科技的不断发展&#xff0c;人们对于信息获取和传播的方式也在不断创新。传统的实体展览馆在空间、时间、地域等方面存在诸多限制&#xff0c;而3D数字展厅则为我们提供了一个全新的解决方案。广州华锐互动致力于为客户提供专业的3D数字展厅定制开发服务&#xff0c;让您的…

4个Pycharm高效插件

大家好&#xff0c;Pycharm是Python最受欢迎的集成开发环境之一&#xff0c;它具有良好的代码助手、漂亮的主题和快捷方式&#xff0c;使编写代码变得简单快捷。话虽如此&#xff0c;开发者仍可以通过使用一些插件来提高在Pycharm中编写Python代码的效率和乐趣&#xff0c;在市…

PID控制

在PID控制中&#xff0c;输出通常是一个控制量&#xff0c;而不是直接的PWM占空比。输出的具体含义可以根据具体的系统和应用而变化。在这段代码中&#xff0c;PID控制器的输出是 output_calc。 而 CCR_duty 是控制施肥系统的PWM占空比&#xff0c;这是通过PID控制的输出和曲线…

华为云之快速部署FTP站点

华为云之快速部署FTP站点 一、本次实践介绍1.1 实践环境简介1.2 本次实践目的 二、vsftpd介绍2.1 vsftpd简介2.2 vsftpd特点 三、环境准备工作3.1 预置实验环境3.2 查看预置环境信息3.3 登录华为云3.4 查看弹性云服务器状态3.5 查看弹性公网IP地址3.6 ssh登录弹性云服务器3.6 查…

System.out.println隐藏字符串

昨天开发的时候遇到一个坑&#xff0c;这个坑几乎浪费了我一整天时间&#xff0c;我甚至现在都不知道其原因。 开发环境 macOS Ventura 13.4 IntelliJ IDEA 2023.1.2 现象 我用java的各种httpclient获取网络上的一个文本文件&#xff0c;获取的文本文件的内容使用System.ou…