unittest(20)- 自动更新表格中数据(5)
# 1. get_data.py
from tools import project_path
import pandas as pd
class GetData:
Cookie = None
AddTel = pd.read_excel(project_path.test_case_path, sheet_name="phone").iloc[0, 0]
# df = pd.read_excel(project_path.test_case_path, sheet_name="phone")
# print(df.iloc[0, 0]) # 获取phone表单中的A1单元格的值
# 2. do_excel.py
# 从表格中获取手机号,进行值的传递
# 每次测试的手机号都不同,如果重复注册,可以使用手工测试,不必再单独写代码。
# 或者直接在表格用例中直接写死一个手机号,表格中只需要保留一个
from openpyxl import load_workbook
from tools.read_config import ReadConfig
from tools import project_path
from account_auto_incre_6.get_data import GetData
class DoExcel:
@classmethod
def get_data(cls, file):
wb = load_workbook(file)
# 读出来的配置项是字符串格式,需要转换成字典格式
mode = eval(ReadConfig.get_config(project_path.case_config_path_auto_incre, "MODE", "mode"))
tel = getattr(GetData, "AddTel") # 从GetData中拿到数据
# tel = cls.get_tel(project_path.test_case_path, "phone") # 通过函数拿到数据
test_data = []
for key in mode:
sheet = wb[key] # 表单名
if mode[key] == "all":
for i in range(2, sheet.max_row+1):
row_data = {}
# 数值类型读出来还是数值,不用使用函数eval转换
row_data["case_id"] = sheet.cell(i, 1).value
row_data["url"] = sheet.cell(i, 2).value
row_data["method"] = sheet.cell(i, 3).value
# row_data["data"] = eval(sheet.cell(i, 4).value)
if sheet.cell(i, 4).value.find("${tel}") != -1: # 表示在这个单元格的值中如果找到了${tel}字符串
row_data["data"] = sheet.cell(i, 4).value.replace("${tel}", str(tel))
tel = tel + 1
else: # 如果没有找到匹配的字符串
row_data["data"] = sheet.cell(i, 4).value
row_data["title"] = sheet.cell(i, 5).value
row_data["expected"] = sheet.cell(i, 6).value
row_data["sheet_name"] = key # 为了写回测试结果时定位表单
test_data.append(row_data)
cls.update_tel(file, "phone", tel) # 写入新数据
else:
for case_id in mode[key]:
row_data = {}
row_data["case_id"] = sheet.cell(case_id+1, 1).value # 注意行号和case_id的关系
row_data["url"] = sheet.cell(case_id+1, 2).value
row_data["method"] = sheet.cell(case_id+1, 3).value
# row_data["data"] = eval(sheet.cell(case_id+1, 4).value)
if sheet.cell(case_id+1, 4).value.find("${tel}") != -1: # 表示在这个单元格的值中如果找到了${tel}字符串
row_data["data"] = sheet.cell(case_id+1, 4).value.replace("${tel}", str(tel))
tel = tel + 1
else: # 如果没有找到匹配的字符串
row_data["data"] = sheet.cell(case_id+1, 4).value
row_data["title"] = sheet.cell(case_id+1, 5).value
row_data["expected"] = sheet.cell(case_id+1, 6).value
row_data["sheet_name"] = key # 为了写回测试结果时定位表单
test_data.append(row_data)
# 也可以不在上述的if else分支中都写一次row_data,而是取完数据后统一替换
# for item in test_data:
# if item['data']['loginName'].find("${tel}") != -1: # 表示在这个单元格的值中如果找到了${tel}字符串
# row_data["data"]['loginName'] = row_data["data"]['loginName'].replace("${tel}", str(tel))
# tel = tel + 1
return test_data
def write_back(self, file, sheet, i, response, test_result):
wb = load_workbook(file)
sheet = wb[sheet]
# 写入测试结果, value必须是数据或者字符串类型才能被写回,写入数据前必须关闭工作簿
sheet.cell(i, 7).value = response
sheet.cell(i, 8).value = test_result
# 保存工作簿
wb.save(file)
@classmethod
def update_tel(cls, file, sheet_name, tel):
wb = load_workbook(file)
sheet = wb[sheet_name]
sheet.cell(2, 1).value = tel
wb.save(file)
# 不使用函数,写一个获取手机号的函数
# @classmethod
# def get_tel(cls, file, sheet_name):
# wb = load_workbook(file)
# sheet = wb[sheet_name]
# tel = sheet.cell(2, 1).value
# return tel
if __name__ == '__main__':
test_data = DoExcel().get_data(project_path.test_case_path)
print(test_data)
print(len(test_data)) # 获取列表元素个数
表格数据如图:

unittest(20)- 自动更新表格中数据(5)的更多相关文章
- unittest(20)- 自动更新表格中的数据(3)
通过函数获取表格中的手机号 # 1. get_data.py from tools import project_path import pandas as pd class GetData: Coo ...
- unittest(20)- 自动更新表格中的测试数据(1)
# 直接给出第一个手机号,而不是从excel中取数据 from openpyxl import load_workbook from tools.read_config import ReadConf ...
- odoo自动更新表中数据
这是追踪信息用的查询语句,__init__方法初始化作用 _order = ctx = dict(context or {}, mail_create_nolog=True) new_id = sup ...
- 自动更新开奖数据的excel文件,供大家下载
自动更新开奖数据的excel文件,供大家下载 2010-03-14 20:22 228492人阅读打印来源:乐彩网 作者:eren 很多人拥有自制excel电子表格,常要更新最基本的开奖信息.如有多期 ...
- 更新表中数据可以使用join
1.在修改数据库的时候,每写完一条SQL语句都要加上一个分号,这样每句之间是有依赖关系的,上面执行不成功不会执行下面的语句. 2.在更新数据库中数据时可以使用join. 例如: update res ...
- [转载]JAVA获取word表格中数据的方案
上一个项目的开发中需要实现从word中读取表格数据的功能,在JAVA社区搜索了很多资料,终于找到了两个相对最佳的方案,因为也得到了不少网友们的帮助,所以不敢独自享用,在此做一个分享. 两个方案分别是: ...
- [原创]JAVA获取word表格中数据的方案
上一个项目的开发中需要实现从word中读取表格数据的功能,在JAVA社区搜索了很多资料,终于找到了两个相对最佳的方案,因为也得到了不少网友们的帮助,所以不敢独自享用,在此做一个分享. 两个方案分别是: ...
- C#读取Excel表格中数据并返回datatable
在软件开发的过程中,经常用到从excel表格中读取数据作为数据源,以下整理了一个有效的读取excel表格的方法. DataTable GetDataTable(string tableName,str ...
- 读取Excel表格中数据原型
写下这篇博客来记录自己的工作,这部分功能是读取Excel表格中的数据,并通过c#中的datagridview控件将读取的数据显示出来.为了方便用户,我设计了一个read按钮,用户点击这个按钮,会弹出打 ...
随机推荐
- UVA 10269 Super Mario,最短路+动态规划
这个题目我昨晚看到的,没什么思路,因为马里奥有boot加速器,只要中间没有城堡,即可不耗时间和脚力,瞬间移动不超过L距离,遇见城堡就要停下来,当然不能该使用超过K次...我纠结了很久,最终觉得还是只能 ...
- chrome安装switchyomega
由于在国外网站找不到下载链接,在国内招了个crx文件,以下为安装crx教程 首先修改后缀为zip,再解压, 得到以下文件 然后在chrome里找到扩展程序, 打开开发者模式,点击-加载已解压的扩展程序 ...
- nginx四层负载及动静分离
阿里云实验10.0.0.132 LB10.0.0.133 web0110.0.0.134 web02 步骤:1.安装nginx1.14 获取官网repo文件 yum install -y nginx ...
- 计量经济与时间序列_ACF与PACF标准差(均标准误)的计算(含代码)
1 我们对于acf和pacf值计算完毕之后,在需要计算两个数值的标准差. 2 acf和pacf的标准差计算略有不同.acf的标准差是一个移动过程,而pacf是一个相对固定过程. 3 我们继 ...
- Adaboost算法及其代码实现
. . Adaboost算法及其代码实现 算法概述 AdaBoost(adaptive boosting),即自适应提升算法. Boosting 是一类算法的总称,这类算法的特点是通过训练若干弱分类器 ...
- Kali 安装 Google 中文输入法
前言 安装了 Linux 并设置中文后,为了操作起来更便捷准备安装一个中文输入法 之前安装搜狗输入法,由于搜狗输入法基于 qt4,估计短期是 GG 了 所以这次选择了 Google 输入法 以下是安装 ...
- Java自学-泛型 通配符
Java 泛型通配符 ? extends super 的用法 示例 1 : ? extends ArrayList heroList<? extends Hero> 表示这是一个Hero泛 ...
- jquery.timepicker.js - 最常用的日期JS控件
客户提了个需求,输入日期,想也不用想,立刻翻查Jquery,发现是有timepicker.js这个控件,马上就用. 1. 导入库 <script src="https://cdnjs. ...
- 二、Shell脚本高级编程实战第二部
一.什么是变量? 变量就是一个固定的字符串替代更多更复杂的内容,当然内容里面可能还有变量.路径.字符串等等内容,最大的特点就是方便,更好开展工作 1.变量有环境变量(全局变量)和局部变量 环境变量就是 ...
- [Algo] 175. Decompress String II
Given a string in compressed form, decompress it to the original string. The adjacent repeated chara ...