利用Python实现Excel合并单元格

最近在工作中需要批量处理一些Excel文件,为了更直观的展示数据,需要对Excel中的单元格进行合并处理。因为一直使用Pandas实现Excel读写操作,而Pandas无法将单元格进行合并,利用Python的xlsxwriter模块可以实现Excel合并单元格。帖子 python之DataFrame写excel合并单元格 中提供了一种方法,但在使用中会出现一些问题,比如无法处理字符串等类型数据。通过修改方法,定义了一个excel_merge_cells函数,基本可以满足日常利用Python实现Excel合并单元格的需求。

原帖方法

在工作中经常遇到需要将数据输出到excel,且需要对其中一些单元格进行合并,比如如下表表格,需要根据A列的值,合并B、C列的对应单元格


1、定义一个MY_DataFrame类,继承DataFrame类,这样能很好的利用pandas的很多特性,而不用自己重新组织数据结构。
2、定义一个my_mergewr_excel方法,参数分别为:输出excel的路径、用于判断是否需要合并的key_cols列表、用于指明哪些列上的单元格需要被合并的列表
3、将MY_DataFrame封装为一个My_Module模块,以备重用。

合并的算法如下:

1、根据给定参数的【关键列】,进行分组计数和排序,添加CN和RN两个辅助列
2、判断CN大于1的,该分组需要合并,否则该分组(行)无需合并(CN=1说明这个分组数据行是唯一的,无需合并)
3、对应需要合并的分组,判断当前列是不是在给定参数【合并列】中,是则用合并写excel单元格,否则就是普通的写excel单元格。
4、在需要合并的列中,如果对于的RN=1则调用merge_range,一次性写想下写CN个单元格,如果RN>1则跳过该单元格,因为在RN=1的时候,已经合并写了该单元格,若再重复调用erge_range,打开excel文档时会报错。

用图解释如下:

具体代码如下:
# -*- coding: utf-8 -*-
"""
Created on 20170301
@author: ARK-Z
"""
import xlsxwriter
import pandas as pdclass My_DataFrame(pd.DataFrame):def __init__(self, data=None, index=None, columns=None, dtype=None, copy=False):pd.DataFrame.__init__(self, data, index, columns, dtype, copy)def my_mergewr_excel(self,path,key_cols=[],merge_cols=[]):# sheet_name='Sheet1', na_rep='', float_format=None, columns=None, header=True, index=True, index_label=None, startrow=0, startcol=0, engine=None, merge_cells=True, encoding=None, inf_rep='inf', verbose=True):self_copy=My_DataFrame(self,copy=True)line_cn=self_copy.index.sizecols=list(self_copy.columns.values)if all([v in cols for i,v in enumerate(key_cols)])==False:     #校验key_cols中各元素 是否都包含与对象的列print("key_cols is not completely include object's columns")return Falseif all([v in cols for i,v in enumerate(merge_cols)])==False:  #校验merge_cols中各元素 是否都包含与对象的列print("merge_cols is not completely include object's columns")return False    wb2007 = xlsxwriter.Workbook(path)worksheet2007 = wb2007.add_worksheet()format_top = wb2007.add_format({'border':1,'bold':True,'text_wrap':True})format_other = wb2007.add_format({'border':1,'valign':'vcenter'})for i,value in enumerate(cols):  #写表头#print(value)worksheet2007.write(0,i,value,format_top)#merge_cols=['B','A','C']#key_cols=['A','B']if key_cols ==[]:   #如果key_cols 参数不传值,则无需合并self_copy['RN']=1self_copy['CN']=1else:self_copy['RN']=self_copy.groupby(key_cols,as_index=False).rank(method='first').ix[:,0] #以key_cols作为是否合并的依据self_copy['CN']=self_copy.groupby(key_cols,as_index=False).rank(method='max').ix[:,0]#print(self)for i in range(line_cn):if self_copy.ix[i,'CN']>1:#print('该行有需要合并的单元格')for j,col in enumerate(cols):#print(self_copy.ix[i,col])if col in (merge_cols):   #哪些列需要合并if self_copy.ix[i,'RN']==1:  #合并写第一个单元格,下一个第一个将不再写worksheet2007.merge_range(i+1,j,i+int(self_copy.ix[i,'CN']),j, self_copy.ix[i,col],format_other) ##合并单元格,根据LINE_SET[7]判断需要合并几个#worksheet2007.write(i+1,j,df.ix[i,col])else:pass#worksheet2007.write(i+1,j,df.ix[i,j])else:worksheet2007.write(i+1,j,self_copy.ix[i,col],format_other)#print(',')else:#print('该行无需要合并的单元格')for j,col in enumerate(cols):#print(df.ix[i,col])worksheet2007.write(i+1,j,self_copy.ix[i,col],format_other)wb2007.close()self_copy.drop('CN', axis=1)self_copy.drop('RN', axis=1)
调用代码:

import My_ModuleDF=My_DataFrame({'A':[1,2,2,2,3,3],'B':[1,1,1,1,1,1],'C':[1,1,1,1,1,1],'D':[1,1,1,1,1,1]})DF
Out[120]: A  B  C  D
0  1  1  1  1
1  2  1  1  1
2  2  1  1  1
3  2  1  1  1
4  3  1  1  1
5  3  1  1  1DF.my_mergewr_excel('000_2.xlsx',['A'],['B','C'])

————————————————
版权声明:本文为CSDN博主「周小科」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/cakecc2008/article/details/59203980

修改后方法

利用Python进行Excel文件读取并分析多数采用Pandas模块进行,所以直接将方法定义为一个名为 excel_merge_cells 的函数,代码如下:

import pandas as pd
import xlsxwriterdef excel_merge_cells(df, save_name, key_cols=[], merge_cols=[]):'''key_cols:用于判断是否需要合并的key_cols列表merge_cols:用于指明哪些列上的单元格需要被合并的列表'''self_copy = df.copy(deep=True)line_cn = self_copy.shape[0]self_copy.index = list(range(line_cn))cols = list(self_copy.columns)self_copy['temp_col'] = 1if all([v in cols for v in key_cols]) == False:   # 校验key_cols中各元素 是否都包含与对象的列raise ValueError("key_cols is not completely include object's columns")if all([v in cols for v in merge_cols]) == False: # 校验merge_cols中各元素 是否都包含与对象的列 raise ValueError("merge_cols is not completely include object's columns")wb = xlsxwriter.Workbook(save_name)worksheet = wb.add_worksheet()format_top = wb.add_format({'border':1, 'bold':True, 'text_wrap':True})format_other = wb.add_format({'border':1,'valign':'vcenter'})for i, value in enumerate(cols):  # 写表头worksheet.write(0, i, value, format_top)if key_cols == []:       # 如果key_cols 参数不传值,则无需合并,RN和CN为辅助列self_copy['CN'] = 1  # 判断CN大于1的,该分组需要合并,否则该分组(行)无需合并(CN=1说明这个分组数据行是唯一的,无需合并)self_copy['RN'] = 1  # RN为需要合并一组中第几行,CN=1,RN=1;CN=5,RN=1,...5else:self_copy['CN'] = self_copy.groupby(key_cols, as_index=False)['temp_col'].rank(method='max')['temp_col']    # method='max',对整个组使用最大排名self_copy['RN'] = self_copy.groupby(key_cols, as_index=False)['temp_col'].rank(method='first')['temp_col']  # method='first',按照值在数据中出现的次序分配排名for i in range(line_cn):if self_copy.loc[i, 'CN'] > 1:for j, col in enumerate(cols):if col in (merge_cols):if self_copy.loc[i, 'RN'] == 1: # 合并写第一个单元格,下一个第一个将不再写worksheet.merge_range(i+1, j, i+int(self_copy.loc[i, 'CN']), j, self_copy.loc[i, col], format_other)'''合并 开始行,开始列,结束行,结束列,值,格式''''''因为已经写了表头所以从i+1行开始写'''else:passelse:worksheet.write(i+1, j, self_copy.loc[i, col], format_other)else:for j, col in enumerate(cols):worksheet.write(i+1, j, self_copy.loc[i, col], format_other)wb.close()

函数需要传入的参数如下:

  • df:需要进行合并单元格处理的DataFrame
  • save_name:处理结果需要保存的路径及文件名
  • key_cols:用于判断是否需要合并的key_cols列表
  • merge_cols:用于指明哪些列上的单元格需要被合并的列表

利用Python实现Excel合并单元格相关推荐

  1. python读写excel(合并单元格)

    读取 import xlrddef read_excel(file_path):# 获取数据data = xlrd.open_workbook(file_path)# 获取所有sheet名字sheet ...

  2. python处理excel合并单元格的拆分和填补

    目录 一.问题需求 二.解决办法 一.问题需求 本篇博文可以说是博主另一篇博文的反向需求--博文:<python实现excel单元格对象合并>.        简单描述下问题,借助示例来说 ...

  3. python合并word单元格_python之DataFrame实现excel合并单元格_python

    这篇文章主要为大家详细介绍了python之DataFrame实现excel合并单元格,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 在工作中经常遇到需要将数据输出到excel,且需要对其中一些单元 ...

  4. 利用Pandas拆分Excel的单元格为多行并保留其他行的数据

    利用Pandas拆分Excel的单元格为多行并保留其他行的数据 1. 需求 2. Pandas解决需求 2.1 准备工作 2.2 Python程序执行 3. Pandas实现需求过程详解 3.1 碎碎 ...

  5. asp.net mvc excel合并单元格_excel统计求和:如何在合并后的单元格中复制求和公式...

    编按:哈喽,大家好!又到了一年一度的双十一购物狂欢节,小伙伴们有没有蠢蠢欲动呢?钱包都准备好了吗!这个双十一,大家都盯上了哪些好物呢?哪类产品的开销又会成为你贡献双十一销售额的主力军呢?赶紧在exce ...

  6. html表格里面怎么合并单元格的快捷键,excel合并单元格快捷键是什么

    excel合并单元格快捷键是什么 快捷键的熟练使用可以帮助我们在工作中提高效率,那么excel合并单元格快捷键是什么呢?接下来为大家讲解excel合并单元格快捷键设置方法的图文演示. 合并单元格在ex ...

  7. Java POI 对Excel合并单元格的数据处理

    Java POI 对Excel合并单元格的数据处理 最近在项目开发过程中,有个一个导入Excel文件处理合并单元格数据的需求,就自己在网上找了一个模板,自己进行二次开发来开发需求. Excel工具类 ...

  8. springboot项目导出excel 合并单元格表格

    springboot项目导出excel 合并单元格表格 导出效果 业务controller 业务数据 业务实体类 注解MyExcel.java 注解 MyExcels 导出工具类MyExcelUtil ...

  9. python 读取excel中单元格的内容

    python 读取excel中单元格的内容 excel文件内容: 读取excel代码: # coding=utf-8 import xlrd import sysreload(sys) sys.set ...

  10. html统计表合并单元格的快捷键,excel合并单元格的快捷键是什么?

    excel合并单元格的快捷键是什么?? Excel是一款专业制作表格的办公软件,对于办公的网友来说似乎必不可少.在对单元格进行编辑操作的时候大家通常会需要做一些标题或者写入较多的内容,这个时候通常使用 ...

最新文章

  1. 错误记录 ---------------------- 乱七八糟
  2. 第十五课.马尔科夫链蒙特卡洛方法
  3. 项目经验分享——Java常用工具类集合 转
  4. 内控与IT安全的关系,IT内控与安全审计的关系
  5. Python Django 可变参数*与**的区别
  6. 网络安全:HTTP Host 头攻击相关知识介绍
  7. 二狗叫你制作千M网线的线序及方法
  8. [2021 CSP-S提高组] 题解(廊桥分配+括号序列+回文+交通规划)
  9. mysql的util_JDBC连接mysql工具类Util供大家参考
  10. Linux学习笔记-Linux下读写文件
  11. cad高程如何提取到cass软件_从CAD平面图中提取坐标生成数据表
  12. Disney牵手联想发布AR头显,还有配备激光剑的AR游戏《星球大战》
  13. 北航计算机专业怎么样,选计算机专业,北航、南大、中科大3校如何选择?选北航更有优势...
  14. 编写php代码老出错,SQL出错原因比较(php代码)
  15. 值得学习的100个网站推广方法。新站推广必备
  16. linux 备份命令
  17. ppt字体颜色如何修改
  18. 递归下降文法C语言实验报告,编译原理实验报告:实验二编写递归下降语法分析程序...
  19. GB2312 GBK BIG5
  20. keil+stm32cubemx创建STM32F767芯片的RT-Thread工程

热门文章

  1. 还在加班?你应该把生命浪费在美好的事物上
  2. css相对图片加文字,html+css怎么在图片上添加文字
  3. html5 video断点续播,Vue中集成vue-video-player及相关api/vue视频播放插件/支持断点续播...
  4. 秒拍3月短视频榜单发布,MCN化是2017年的大势所趋?
  5. 使用JavaScript实现动态效果
  6. Filebeat日志采集
  7. 手把手带你撸一个校园APP(四):APP功能设计及主页面框架
  8. 李彦宏高中全国计算机比赛,扒一扒IT大佬高考:马云数学1分考北大 李彦宏是状元...
  9. android格式化外置u盘,Android5.x+ 格式化外部存储(u盘, sdcard)的方法
  10. python学习笔记——语法基础