这篇文章主要为大家详细介绍了python之DataFrame实现excel合并单元格,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

pandas中的to_excel方法只能对索引进行合并,而xlsxwriter中,虽然提供有merge_range方法,但是这只是一个和基础的方法,每次都需要编写繁琐的测试才能最终调好,而且不能很好的重用。所以想自己写一个方法,结合dataframe和merge_range。大概思路是:

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 pd

class 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.size

cols=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 False

if 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']=1

self_copy['CN']=1

else:

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_Module

DF=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 1

DF.my_mergewr_excel('000_2.xlsx',['A'],['B','C'])

效果如下:

也可以设置合并A、B列:

DF.my_mergewr_excel('000_2.xlsx',['A'],['A','B'])

效果如下:

以上就是python之DataFrame实现excel合并单元格_python的详细内容,更多请关注php中文网其它相关文章!

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

python合并word单元格_python之DataFrame实现excel合并单元格_python相关推荐

  1. python html网页合并单元格,python之DataFrame实现excel合并单元格

    在工作中经常遇到需要将数据输出到excel,且需要对其中一些单元格进行合并,比如如下表表格,需要根据a列的值,合并b.c列的对应单元格 pandas中的to_excel方法只能对索引进行合并,而xls ...

  2. html统计表合并单元格的快捷键,多个单元格内容合并为一个单元格,3种用法-excel合并单元格快捷键...

    如何将多个单元格内容合并成一个单元格?想要实现这个效果,其实有很多种办法.比如说借助记事本.剪切板或者两端对齐都可以实现的,不过本期帮主不想介绍这些种方法,主要是推荐3个函数的用法. 第一种:连字符& ...

  3. python excel合并_Python把多个Excel合并成一个Excel

    #! /usr/bin/python3 # -*- coding: utf-8 -*- # @Time : 2018/8/31 16:31 # @File : more_to_one # @Softw ...

  4. qtableview设置单元格颜色_一键解锁Excel自定义单元格格式!

    实际工作中,常需要我们对单元格格式进行自定义设置,来突出显示我们需要看到的数据. 在自定义单元格格式时,我们常用如下方式先打开[设置单元格格式]对话框,再点击数字分类下的自定义: [开始]选项卡下的[ ...

  5. html文本框向下合并,Word中多个文本框该怎么合并?

    在使用word制作流程图的时候往往会使用到较多的文本框,文本框绘制完成后需要将一部分或者所有的文本框进行组合.但是一个一个的去点击文本框效率很低,而且还会遇到马上所有文本框就要选中完毕时某一个文本框没 ...

  6. 在合并单元格中数组公式无效_Excel合并单元格查找,公式没错,结果为0,你知道这是什么原因吗...

    如果说你能够熟练运用Excel函数中的查询家族,可以说大多数的问题你都可以解决了.但很多情况下,我们会遇到脑壳疼的问题,比如你看看下面的例子. 下图中,需要在右边的表格中通过E列的机型查找其对应的品牌 ...

  7. Python将word表格存入excel —— 格式化pg参数手册

    一. 背景 收到一份<PostgreSQL13商用文档之PG参数参考手册>,打算学习一下,打开文档一看,151页T_T.参数虽然有分类,但不太有规律,word文档格式如下: 个人觉得如果用 ...

  8. wireshark合并多个文件_小技巧:快速合并多个excel文件(收藏版)

    我们在日常工作或科研中,总会遇到需要汇总多个excel的情况,若仅仅是几个表格,大多人会直接复制,若有上百个表格呢?     那么小编就告诉大家一个稍微简洁一点的方法,将多个单独的excel表格快速合 ...

  9. excel怎么启用宏_轻便免费的Excel合并工具,支持wps和office全系统

    Excel合并工具绿色程序版是一款由吾爱网友ermituofo分享制作的Excel合并软件,软件支持wps和office全系统,很多用户发表格给其他用户之后自己要使用合并处理就很麻烦,有了这个工具,就 ...

最新文章

  1. @ngrx入坑angular的schema,爽的一逼!
  2. Hadoop 运行jar包时 java.lang.ClassNotFoundException: Class com.zhen.mr.RunJob$HotMapper not found...
  3. TensorFlow 从零到helloWorld
  4. 用虚拟机安装了红帽后,我确实没设置用户名密码,但现在一打开就让输入用户名密码。这种情况该怎么办??
  5. java蓝桥杯 试题-基础练习-十六进制转八进制
  6. 理解SVG的viewport,viewBox【1】
  7. java 类的域_Java类中对象域的初始化
  8. js记录访问网页的ip_亚马逊新手记录之避免店铺关联
  9. 合同管理系统主要增加了安全性,对于大型企业作用重大
  10. 为什么RTC晶振频率是32768Hz
  11. qtablewidget翻页禁止_PyQt—QTableWidget实现翻页功能
  12. 华硕天选2和华硕天选3哪个好 华硕天选2和华硕天选3区别
  13. 2022中国大学专业排名公布:集成电路相关专业哪家强?
  14. 文件上传漏洞靶场upload-labs学习(pass1-pass5)
  15. oracle删除table不进回收站,清除当前用户的回收站
  16. 2020-10-24经典语录合集(一)
  17. 华北电大学计算机考研资料汇总
  18. 三星mzvlb1t0hblr是什么固态_三星MZVLB512HAJQ-000L7 SSD固态硬盘开机卡死在LOGO界面数据恢复成功...
  19. Jpg图片怎么变成gif动图?教你快速三步在线做gif
  20. 已解决-Outlook 收件箱全部标记为已读,但还是有未读数字提示

热门文章

  1. Apache Spark软件包,从XML到JSON
  2. netbeans 源文件_具有NetBeans,嵌入式GlassFish,JPA和MySQL数据源的Arquillian
  3. js删除两个集合中共同元素_多个集合中的共同和独特元素
  4. JDK 9:模块系统状态的重点
  5. Spring MVC中的验证组
  6. 通过Katas进行Java教程:网球比赛(轻松)
  7. 使用RequestHandlerRetryAdvice重试Web服务操作
  8. 将社交登录添加到Spring MVC Web应用程序:注册和登录
  9. Spring MVC表单教程
  10. 使用Spring @Autowired List的责任链