python读取所有sheet内容到另一个文件中

news2025/1/12 1:01:26

 实现效果:

将原excel中的步骤、预期效果列按回车拆成多行数据,其余字段值填充其他数据

实现结果:

# This is a sample Python script.

# Press Shift+F10 to execute it or replace it with your code.
# Press Double Shift to search everywhere for classes, files, tool windows, actions, and settings.


# def print_hi(name):
#     # Use a breakpoint in the code line below to debug your script.
#     print(f'Hi, {name}')  # Press Ctrl+F8 to toggle the breakpoint.
#
#
# # Press the green button in the gutter to run the script.
# if __name__ == '__main__':
#     print_hi('PyCharm')
#
# # See PyCharm help at https://www.jetbrains.com/help/pycharm/

import openpyxl, re


def SplitLine():
    book = openpyxl.load_workbook(file_path + "\\" + raw_excel)    # 读取原excel
    wb = book.active
    book_2 = openpyxl.load_workbook(file_path + "\\" + "result.xlsx")  # 读取新建的result
    wb_2 = book_2.active

    name = ["TCID", "Test Summary", "Test Priority", "Step", "Data", "Expected Result", "Test Repository Path",
            "Pre-condition", "TestCaseType", "Automation", "LinkType", "LinkIssue"]
    # name = ["所属模块(*)", "用例标题(*)", "前置条件", "步骤", "预期结果", "优先级"]  # result表格的首行内容
    for a in range(1, len(name) + 1):
        wb_2.cell(row=1, column=a, value=name[a - 1])  # 写入result的首行

    j = 2 #新建excel的行数
    k = 0 #回车数量
    b = 2

    #遍历所有的sheet
    for sheet_name in book.sheetnames:
        print(book.sheetnames)
        sheet = book[sheet_name]
        a = sheet.cell(2,2).value
        print(a)
        print(sheet)


        print(sheet.max_row)
        with open(file_path + "\\" + "result.xlsx",encoding='utf-8') as f:
            for i in range(2, sheet.max_row+1):

                # 读取原excel的每行内容
                Test_Repository_Path = sheet.cell(i, 1).value


                try:
                    Test_Repository_Path = "/对外系统用例/"+sheet_name+"/"+Test_Repository_Path
                except:
                    print("继续执行")
                # print(wb.cell(1, 1).value)
                print(Test_Repository_Path)
                Test_Summary = sheet.cell(i, 2).value
                Pre_condition = sheet.cell(i, 3).value
                Data = sheet.cell(i, 4).value
                print(Data)
                Expected_Result = sheet.cell(i, 5).value


                # 将内容写入result中
                wb_2.cell(row=j, column=7, value=Test_Repository_Path)
                wb_2.cell(row=j, column=2, value=Test_Summary)
                wb_2.cell(row=j, column=3, value="Medium")
                wb_2.cell(row=j, column=8, value=Pre_condition)
                wb_2.cell(row=j, column=5, value=Data)
                wb_2.cell(row=j, column=6, value=Expected_Result)
                wb_2.cell(row=j, column=9, value="功能用例")
                wb_2.cell(row=j, column=10, value="否")
                wb_2.cell(row=j, column=1, value=b-1)
                wb_2.cell(row=j, column=4, value=1)


                try:
                    # 对Data中的内容进行识别
                    if '\n' in Data:
                        k = Data.count("\n")
                        k = k + 1  # 数据量比“;”的个数多一个
                        Data_2 = []
                        Expected_Result_2 = []
                        #循环所有的回车数量,分隔到每一行中
                        for p in range(0, k):
                            Data_2.append(re.split(r"[\n]\s*", Data.split("\n")[p]))
                            Expected_Result_2.append(re.split(r"[\n]\s*", Expected_Result.split("\n")[p]))

                            # print(Data_2)
                            # print(Data_2[p][0])
                            # # print(Data_2[0][p])
                            wb_2.cell(row=j, column=5, value=str(Data_2[p][0]))
                            wb_2.cell(row=j, column=6, value=str(Expected_Result_2[p][0]))
                            wb_2.cell(row=j, column=4, value=p+1)
                            wb_2.cell(row=j, column=1, value=b - 1)

                            # print(wb_2.cell(row=j, column=4).value)
                            j = j + 1
                    else:
                        wb_2.cell(row=j, column=5, value=Data)
                        wb_2.cell(row=j, column=6, value=Expected_Result)
                        wb_2.cell(row=j, column=1, value=b - 1)

                        j = j + 1

                except:
                    print("继续执行")
                b = b + 1



    book_2.save(file_path + "\\" + "result.xlsx")  # 保存excel



if __name__ == "__main__":
    file_path =r'C:\Users\12133\Desktop'
    raw_excel ='对外系统用例.xlsx'
    # file_path = input("file_path:")
    # raw_excel = input("excel_name:")
    SplitLine()

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

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

相关文章

单目相机测距(3米范围内)二维码实现方案(python代码 仅仅依赖opencv)

总体思路:先通过opencv 识别二维码的的四个像素角位置,然后把二维码的物理位置设置为 cv::Point3f(-HALF_LENGTH, -HALF_LENGTH, 0), //tl cv::Point3f(HALF_LENGTH, -HALF_LENGTH, 0), //tr cv::Point3f(HALF_LENGTH, HALF_LENGTH, 0), //br cv::P…

我有才满足于自媒体行业的知识付费平台课程

用户管理 提供会员特权和积分奖励,提高用户忠诚度和购买力。 用户通过在平台上进行消费、签到、参与活动等方式获取积分,用于兑换丰厚奖品或提升会员等级。增强用户的参与感与忠诚度,提高用户粘性,并刺激用户的购买力。 为用户打…

3.镜像加速器

目录 1 阿里云 2 网易云 从网络上拉取镜像的时候使用默认的源可能会慢,用国内的源会快一些 1 阿里云 访问 阿里云-计算,为了无法计算的价值 然后登录,登录后搜索 容器镜像服务 点击容器镜像服务 点击管理控制台 点击 镜像工具->镜像…

vue3 vue-cropper@next 实现图片裁切功能

Vue Cropper 实现上传图片预览&#xff0c;裁切上传效果 下载 pnpm add vue-croppernext使用 <template><inputref"inputRef"class"hidden"accept".png,.jpeg,.jpg"multipletype"file"change"handleUploadChange&quo…

基于ssm实现的工资管理系统

一、系统架构 前端&#xff1a;jsp | jquery | layui 后端&#xff1a;spring | springmvc | mybatis 环境&#xff1a;jdk1.8 | mysql | maven 二、代码及截图 三、功能介绍 01. 登录页 02. 首页 03. 用户管理-基本资料 04. 用户管理-修改密码 05. 人事管理-部门列表…

Leetcode—409.最长回文串【简单】

2023每日刷题&#xff08;四十八&#xff09; Leetcode—409.最长回文串 强烈吐槽&#xff01;&#xff01;&#xff01; 非常不理解&#xff0c;同样的代码&#xff0c;为什么C跑不了C就跑得了&#xff0c;力扣编译器是对C语言有歧视吗&#xff1f;&#xff1f;&#xff1f;…

【springboot原理篇】Bean的加载方式,面试必看

&#x1f308;键盘敲烂&#xff0c;年薪30万&#x1f308; 目录 一、上古时代原始方式&#xff1a; &#x1f4d5;XML文件 ~~bean定义 &#x1f440;演示获取bean&#xff1a; ❌缺点&#xff1a; &#x1f4d5;注解方式&#xff1a; ~~component ~~指定扫描路径&#…

如何使用 Oracle SQL Developer 连接 pgvector

如何使用 Oracle SQL Developer 连接 pgvector 1. 下载 postgresql 的 jdbc 驱动2. Oracle SQL Developer 配置第三方驱动3. Oracle SQL Developer 配置 postgres 连接 1. 下载 postgresql 的 jdbc 驱动 访问 https://jdbc.postgresql.org/download/&#xff0c;下载驱动&…

Linux部署HDFS集群前置准备

二、VMware准备Linux虚拟机 三、VMware虚拟机系统设置 &#xff08;一&#xff09;对三台虚拟机完成主机名、固定IP、SSH免密登陆等系统设置 1.配置固定IP地址 打开控制台&#xff0c;切换到root用户 su -修改主机名、IP地址 vim /etc/sysconfig/network-scripts/ifcfg-ens3…

Temu数据面板:Temu商家必备的数据分析工具

在Temu这个电商平台上&#xff0c;越来越多的商家意识到数据分析的重要性。数据分析可以帮助商家更好地了解店铺的运营情况&#xff0c;从而制定更有效的运营策略&#xff0c;提高销售业绩。而在这个过程中&#xff0c;Temu数据面板成为了一个不可或缺的工具。 先给大家推荐一款…

学习使用三个命令实现在腾讯云服务器TencentOS Server 3.1或者CentOS 8上安装ffmpeg

学习使用三个命令实现在腾讯云服务器TencentOS Server 3.1或者CentOS 8上安装ffmpeg Error: Unable to find a match: ffmpeg添加RPMfusion仓库安装SDL安装ffmpeg执行命令测试 Error: Unable to find a match: ffmpeg 添加RPMfusion仓库 yum install https://download1.rpmfus…

LLM之RAG实战(二):使用LlamaIndex + Metaphor实现知识工作自动化

最先进的大型语言模型&#xff08;LLM&#xff09;&#xff0c;如ChatGPT、GPT-4、Claude 2&#xff0c;具有令人难以置信的推理能力&#xff0c;可以解锁各种用例——从洞察力提取到问答&#xff0c;再到通用工作流自动化。然而&#xff0c;他们检索上下文相关信息的能力有限。…

CCF CSP认证 历年题目自练Day51

此题又丑又长可以直接从题目分析&#xff08;个人理解&#xff09;部分看 题目 试题编号&#xff1a; 201812-3 试题名称&#xff1a; CIDR合并 时间限制&#xff1a; 1.0s 内存限制&#xff1a; 512.0MB 样例输入 2 1 2 样例输出 1.0.0.0/8 2.0.0.0/8 样例输入 2 10/9 10…

2022年9月26日 Go生态洞察:Go运行时4年后的进展

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

不瞒各位,不安装软件也能操作Xmind文档

大家好&#xff0c;我是小悟 作为搞技术的一个人群&#xff0c;时不时就要接收产品经理发过来的思维脑图&#xff0c;而此类文档往往是以Xmind编写的&#xff0c;如果你的电脑里面没有安装Xmind的话&#xff0c;不好意思&#xff0c;是打不开这类后缀结尾的文档。 打不开的话…

Web漏洞分析-SQL注入XXE注入(中上)

随着互联网的不断普及和Web应用的广泛应用&#xff0c;网络安全问题愈发引起广泛关注。在网络安全领域中&#xff0c;SQL注入和XXE注入是两个备受关注的话题&#xff0c;也是导致许多安全漏洞的主要原因之一。本博客将深入研究这两种常见的Web漏洞&#xff0c;带您探寻背后的原…

隐写2-MISC-bugku-解题步骤

——CTF解题专栏—— 声明&#xff1a;文章由作者weoptions学习或练习过程中的步骤及思路&#xff0c;非正式答案&#xff0c;仅供学习和参考。 题目信息&#xff1a; 题目&#xff1a;隐写2 作者&#xff1a;harry 提示&#xff1a;f1g{xxx} 解题附件&#xff1a; 解题思路…

蓝桥杯物联网竞赛_STM32L071_9_按键矩阵扩展模块

原理图&#xff1a; 矩阵按键原理图&#xff1a; 实验板接口原理图&#xff1a; 得到对应图&#xff1a; 扫描按键原理&#xff1a; 按键的COLUMN1、2、3分别制0&#xff0c;每次只允许其中一个为0其他都是1&#xff08;POW1和POW2正常状况为上拉&#xff09;&#xff0c;当有…

深入了解Java Duration类,对时间的精细操作

阅读建议 嗨&#xff0c;伙计&#xff01;刷到这篇文章咱们就是有缘人&#xff0c;在阅读这篇文章前我有一些建议&#xff1a; 本篇文章大概6000多字&#xff0c;预计阅读时间长需要5分钟。本篇文章的实战性、理论性较强&#xff0c;是一篇质量分数较高的技术干货文章&#x…

为了让亲戚也能用上chatgpt,我决定建一个代理站点

&#xff08;本文试着用gpt优化了一下&#xff0c;效果有&#xff0c;但是不多&#xff09; ChatGPT在编程中的应用 当ChatGPT刚出来的时候&#xff0c;我尝试了几次&#xff0c;感觉它就像是一个高级版的搜索引擎。但在过去的一个月里&#xff0c;我在公司经常使用GPT来查询…