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

 实现效果:

将原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, redef SplitLine():book = openpyxl.load_workbook(file_path + "\\" + raw_excel)    # 读取原excelwb = book.activebook_2 = openpyxl.load_workbook(file_path + "\\" + "result.xlsx")  # 读取新建的resultwb_2 = book_2.activename = ["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#遍历所有的sheetfor sheet_name in book.sheetnames:print(book.sheetnames)sheet = book[sheet_name]a = sheet.cell(2,2).valueprint(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).valuetry:Test_Repository_Path = "/对外系统用例/"+sheet_name+"/"+Test_Repository_Pathexcept:print("继续执行")# print(wb.cell(1, 1).value)print(Test_Repository_Path)Test_Summary = sheet.cell(i, 2).valuePre_condition = sheet.cell(i, 3).valueData = sheet.cell(i, 4).valueprint(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 + 1else: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 + 1except:print("继续执行")b = b + 1book_2.save(file_path + "\\" + "result.xlsx")  # 保存excelif __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.mzph.cn/news/196172.shtml

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

相关文章

min函数的栈(最小栈),剑指offer,力扣

目录 题目地址: 相同题目题解地址: 题目: 我们直接看题解吧: 解题方法: 审题目事例提示: 解题分析: 解题思路: 补充说明: 代码实现: 题目地址: L…

防火墙规则保存及自定义链

目录 防火墙规则保存 备份工具 iptables services 自定义链 自定义链实现方式 删除自定义链 重命名自定义链 防火墙规则保存 命令:iptables -save 工具:iptables services [rootlocalhost ~]# iptables-save > /opt/iptables.bak #将文件保存…

二阶变系数线性微分方程

1、变量替换法 欧拉方程 是常数&#xff0c;是已知的函数。 二阶欧拉方程 (1) 当时&#xff0c;令,则 代入&#xff08;1&#xff09;中&#xff0c; .这样就把欧拉方程&#xff0c;化成了二阶常系数非齐次微分方程 当x<0时&#xff0c;令, 例题 解:令,则 代入上面的推…

上海展会会议如何做好媒体宣传?

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 要做好上海展会会议的媒体宣传&#xff0c;可以采取以下几个步骤&#xff1a; 1.明确宣传目标和受众&#xff1a;首先&#xff0c;明确宣传的主要目标和目标受众。了解受众的喜好和习惯…

希宝猫罐头怎么样?专业人士告诉你营养好的猫罐头推荐

作为一个6年铲屎官来说&#xff0c;买过的猫罐头可以说是不计其数啦。对于猫罐头品牌选购和喂养相关知识&#xff0c;我还是有点心得的。希宝猫罐头怎么样呢&#xff1f; 希宝猫罐头采用了先进的加工工艺&#xff0c;注重产品的包装和密封性&#xff0c;包装设计比较符合年轻人…

Wnmp本地搭建结合内网穿透实现远程访问本地Wnmp服务

文章目录 前言1.Wnmp下载安装2.Wnmp设置3.安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4.固定公网地址访问 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的 人工智能学习网站&#xff0c; 通俗易懂&a…

使用 PHPMailer 实现邮件的实时发送

&#x1f482; 个人网站:【 海拥】【神级代码资源网站】【办公神器】&#x1f91f; 基于Web端打造的&#xff1a;&#x1f449;轻量化工具创作平台&#x1f485; 想寻找共同学习交流的小伙伴&#xff0c;请点击【全栈技术交流群】 今天我们利用GitHub上20K星星的项目 PHPMailer…

知虾主页:为商家和市场分析师提供的数据分析工具

知虾是专为Shopee&#xff08;虾皮购物&#xff09;平台而设计的数据分析工具&#xff0c;为商家和市场分析师提供了丰富的功能和信息。本文将介绍知虾主页上的各项功能&#xff0c;并详细解释如何利用这些功能来分析市场趋势、产品分析和竞争对手分析等方面的数据。无论您是新…

aidegen:为AOSP代码中Java和C / C ++项目自动生成ide配置

aidegen&#xff1a;为AOSP代码中Java和C / C 项目自动生成ide配置 aosp中模块众多&#xff0c;依赖复杂&#xff0c;如何快速完成ide配置&#xff0c;从而能愉快地在ide中进行代码的导航和跳转是我们需要解决的问题&#xff0c;好在google给我们提供了一款好用的ide配置生成工…

【android开发-14】android中fragment用法详细介绍

1&#xff0c;fragment是什么&#xff1f; Fragment是Android中的一种组件&#xff0c;它在Android 3.0&#xff08;API级别11&#xff09;及以后的版本中引入。Fragment可以用来在Activity中添加一个或多个具有自己的用户界面的片段。它们可以与Activity进行交互&#xff0c;并…

ubuntu离线安装包下载和安装

一、确认本机ubuntu的发行版本 方法1: rootac810:/home/ac810/alex# lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 20.04.6 LTS Release: 20.04 Codename: focal 方法2: rootac810:/home/ac810/alex# cat /…

Taro 学习教程 - - - - - 开发环境的安装 helloworld

一、Taro脚手架安装 npm install tarojs/cli -g // or yarn add tarojs/cli -g // or cnpm install tarojs/cli -g1.1 如何判断taro安装成功 taro -v正常安装成功之后显示如图&#xff1a; 1.2 环境变量配置(自行判断是否需要手动配置) 如果遇到如下问题&#xff0c;则是需要…

EasyV不止可视化|易知微带你打开可视化工具新大门!

可视化工具的发展已经成为当今信息技术领域中的一股不可忽视的力量。如今&#xff0c;人们有了更多的数据和信息需要处理&#xff0c;因此需要一种更加高效、更加直观的手段来呈现这些信息&#xff0c;而可视化工具应运而生。这些工具包括多种类型的图表、地图、仪表板等。随着…

MySQL核心知识点整理大全1-笔记

目录 MySQL 一、MySQL的基本概念 1.数据库 2.表 3.列 4.行 5.主键 6.索引 二、MySQL的安装与配置 1.下载MySQL安装包 2.安装MySQL 3.启动MySQL 4.配置MySQL a.设置监听端口和IP地址 b.设置数据存储路径 c.设置字符集和排序规则 5.测试MySQL 三、MySQL的基本操…

机器学习深度学学习分类模型中常用的评价指标总结记录与代码实现说明

在机器学习深度学习算法模型大开发过程中&#xff0c;免不了要对算法模型进行对应的评测分析&#xff0c;这里主要是总结记录分类任务中经常使用到的一些评价指标&#xff0c;并针对性地给出对应的代码实现&#xff0c;方便读者直接移植到自己的项目中。 【混淆矩阵】 混淆矩阵…

FreeRTOS-软件定时器

软件定时器 在FreeRTOS中可以设置无数个软件定时器&#xff0c;都是基于系统滴答中断。 使用软件定时器需要指定时间&#xff1a;启动定时器和运行回调函数。启动定时器和运行回调函数的间隔为定时器的周期。 使用软件定时器需要指定类型&#xff1a;一次性&#xff08;回调函数…

逆天营销!“保温杯”免费送,月赚600万的秘密大揭露!

导语&#xff1a;听说过“免费送”的商业模式吗&#xff1f;现实中就有这样的案例&#xff0c;有人通过“保温杯免费送”的策略&#xff0c;一个月内狂赚600万&#xff01;你一定想知道这是怎么做到的吧&#xff1f;本文将为你揭示这个神秘商业模式的奥秘&#xff01; 一、疯狂…

java--抽象类的常见应用场景:模板方法设计模式

1.模板方法设计模式解决了什么问题&#xff1f; ①解决方法中存在重复代码的问题。 2.模板方法设计模式的写法 1、定义一个抽象类。 2、在里面定义2个方法 ①一个是模板方法&#xff1a;把相同代码放里面去。 ②一个是抽象方法&#xff1a;具体实现交给子类完成。 分析&…

PyQt6 QFontComboBox字体组合框控件

​锋哥原创的PyQt6视频教程&#xff1a; 2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~共计35条视频&#xff0c;包括&#xff1a;2024版 PyQt6 Python桌面开发 视频教程(无废话…

webpack学习-1.起步

webpack学习-1.起步 1.基础设置2.配置文件的引入3.总结 1.基础设置 首先 webpack是干嘛的呢&#xff0c;用官网的一张图 Webpack 是一个现代的静态模块打包工具。它主要用于将前端应用程序中的各种资源&#xff08;例如 JavaScript、CSS、图片等&#xff09;打包成一个或多个…