首页 > 编程语言 >python 合并同列数据 组合 新的excel

python 合并同列数据 组合 新的excel

时间:2024-10-21 13:43:16浏览次数:6  
标签:merge python excel value col 同列 ws start row


import pandas as pd
from openpyxl import load_workbook

# 读取Excel文件
file_path = 'test.xlsx'  # 替换为你的Excel文件路径
df = pd.read_excel(file_path)

# 显示读取的数据
print(df)

# 打开工作簿
wb = load_workbook(file_path)
ws = wb.active  # 获取活动工作表

# 假设我们要合并的列是第1列(A列),从第二行开始(假设第一行为标题)
start_row = 2
last_row = ws.max_row

# 用于存储上一个唯一值以检测变化
previous_value = None
merge_start_row = None

# 遍历每一行
for row in range(start_row, last_row + 1):
    current_value = ws[f'A{row}'].value  # 第一列的值
    
    # 检测当前值与上一个值
    if current_value == previous_value:
        # 如果值相同,继续合并
        continue
    else:
        # 如果发现新的值,合并之前的单元格(如果有)
        if merge_start_row is not None and row - merge_start_row > 1:
            # 根据合并的行数分别合并其他列
            for col in range(2, 8):  # 从第2列到最后一列
                ws.merge_cells(start_row=merge_start_row, start_column=col, end_row=row - 1, end_column=col)
        
        # 更新为新值
        previous_value = current_value
        merge_start_row = row

# 最后合并最后一组相同的值(如果有)
if merge_start_row is not None and last_row - merge_start_row > 0:
    for col in range(2, 8):
        ws.merge_cells(start_row=merge_start_row, start_column=col, end_row=last_row, end_column=col)

# 保存合并后的文件
wb.save('merged_cells.xlsx')  # 可以另存为新文件


标签:merge,python,excel,value,col,同列,ws,start,row
From: https://www.cnblogs.com/mengluo/p/18489327

相关文章

  • Python小游戏9——天天酷跑
    安装Pygame库。如果你还没有安装,可以使用以下命令:bashpipinstallpygame 游戏代码:pythonimportpygameimportrandom #初始化Pygamepygame.init() #屏幕尺寸SCREEN_WIDTH=800SCREEN_HEIGHT=600screen=pygame.display.set_mode((SCREEN_WIDTH,S......
  • Python小游戏8——贪吃蛇
    贪吃蛇游戏说明蛇可以通过方向键来控制移动,目标是吃掉红色的小方块(食物),每吃掉一个食物,蛇的长度就会增加。如果蛇撞到了墙壁或自己,游戏就会结束。 通过以下命令安装pygame库:bashpipinstallpygame以下是贪吃蛇游戏的代码:pythonimportpygameimportrandom#......
  • 解决python多环境冲突问题
    解决Python多环境冲突问题,以下是一些详细的解决方法:1.使用虚拟环境虚拟环境允许你为每个项目创建独立的Python环境,每个环境可以有自己的库和依赖。常用的工具包括venv、virtualenv和pipenv。使用venvvenv是Python3.3及以上版本自带的模块。#创建虚拟环境python-mvenv......
  • 基于Python的学生考勤管理系统(源码+lw+部署文档+讲解等)
    项目整体介绍基于Python+django的学生考勤管理系统是一款专门为学校设计的高效管理工具。该系统充分利用Python的强大编程能力和django的高效Web框架,实现对学生考勤的全面管理。系统具备学生信息管理功能,可以准确记录学生的基本信息,如姓名、学号、班级等。同时,教......
  • 基于Python+django的学生管理系统(源码+lw+部署文档+讲解等)
    项目整体介绍基于Python+django的学生管理系统是一款功能强大且高效的管理工具。该系统利用Python的灵活性和django的高效框架进行设计与开发。在功能方面,学生管理系统可以实现学生信息的录入、查询、修改和删除。能够详细记录学生的基本信息,如姓名、学号、班级、......
  • Python 自编码器(Autoencoder)算法详解与应用案例
    目录Python自编码器(Autoencoder)算法详解与应用案例引言一、自编码器的基本原理1.1自编码器的结构1.2自编码器的类型二、Python中自编码器的面向对象实现2.1`Autoencoder`类的实现2.2`Trainer`类的实现2.3`DataLoader`类的实现三、案例分析3.1手写数字去噪自......
  • python PyPDF2 切割PDF文件
    pythonPyPDF2切割PDF文件fromPyPDF2importPdfReader,PdfWriterdefsplit_pdf(in_file,out_file,orientation="vertical",percent=0.5):""":paramin_file:待拆分的pdf文件:paramout_path:拆分成单页的pdf文件的存储路径:paramorientation......
  • Python Bagging算法详解与应用案例
    这里写目录标题PythonBagging算法详解与应用案例引言一、Bagging的基本原理1.1Bagging的概念1.2Bagging的步骤1.3Bagging的优势与挑战二、Python中Bagging的面向对象实现2.1`DecisionTree`类的实现2.2`Bagging`类的实现2.3`Trainer`类的实现三、案例分析3.1......
  • Python中的深拷贝与浅拷贝
    目录1.可变对象和不可变对象2.用=赋值的问题3.copy模块登场4.重新认识列表对象5.浅拷贝,深拷贝浅拷贝(copy.copy())一维列表的浅拷贝深拷贝(copy.deepcopy())浅拷贝,深拷贝,直接赋值的区别1.可变对象和不可变对象在Python中,数据类型可以分为两大类:可变对象和不可变对象。常......
  • 使用Python解决化学问题的实用指南
    使用Python解决化学问题的实用指南Python作为一种高级编程语言,因其简洁的语法、强大的库支持和活跃的社区,在科学研究领域得到了广泛应用,特别是在化学领域。Python提供了丰富的科学计算和数据处理库,如NumPy、SciPy、Pandas等,以及专为化学设计的库,如RDKit、OpenBabel等,使得......