首页 前端知识 python webdriver 测试框架数据驱动json文件驱动的方式_webdriver json

python webdriver 测试框架数据驱动json文件驱动的方式_webdriver json

2024-05-03 19:05:22 前端知识 前端哥 141 590 我要收藏

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

需要掌握的地方是对excel的操作,要灵活的找到目标数据

测试数据.xlsx:

路径-D:\test\0627

ExcelUtil.py:

#encoding=utf-8
from openpyxl import load_workbook

class ParseExcel(object):

def init(self, excelPath, sheetName):

将要读取的excel加载到内存

self.wb = load_workbook(excelPath)

通过工作表名称获取一个工作表对象

self.sheet = self.wb.get_sheet_by_name(sheetName)

获取工作表中存在数据的区域的最大行号

self.maxRowNum = self.sheet.max_row

def getDatasFromSheet(self):

用于存放从工作表中读取出来的数据

dataList = []

因为工作表中的第一行是标题行,所以需要去掉

for line in self.sheet.rows:

遍历工作表中数据区域的每一行,

并将每行中各个单元格的数据取出存于列表tmpList中,

然后再将存放一行数据的列表添加到最终数据列表dataList中

tmpList = []
tmpList.append(line[1].value)
tmpList.append(line[2].value)
dataList.append(tmpList)

将获取工作表中的所有数据的迭代对象返回

return dataList[1:]

if name == ‘main’:
excelPath = u’E:\数据驱动\测试数据.xlsx’
sheetName = u"搜索数据表"
pe = ParseExcel(excelPath, sheetName)
print pe.getDatasFromSheet()
for i in pe.getDatasFromSheet():
print i[0], i[1]

加print调试日志:

#encoding=utf-8
from openpyxl import load_workbook

class ParseExcel(object):
def init(self,excelPath,sheetName):
self.wb=load_workbook(excelPath)
self.sheet=self.wb.get_sheet_by_name(sheetName)
self.maxRowNum=self.sheet.max_row

def getDatasFromSheet(self):
dataList=[]
for line in self.sheet.rows:
tmpList=[]
tmpList.append(line[1].value)
print “line[1].value”,line[1].value
tmpList.append(line[2].value)
print “line[2].value”,line[2].value
dataList.append(tmpList)
print dataList[1:]
return dataList[1:]

if name==‘main’:
excelPath=u"d:\test\0627\测试数据.xlsx"
sheetName=u"搜索数据表"
pe=ParseExcel(excelPath,sheetName)
print pe.getDatasFromSheet()
for i in pe.getDatasFromSheet():
print i[0],i[1]
单独运行结果:
D:\test\0627>python  ExcelUtil.py
ExcelUtil.py:7: DeprecationWarning: Call to deprecated function get_sheet_by_name (Use wb[sheetname]).
self.sheet=self.wb.get_sheet_by_name(sheetName)
line[1].value 搜索词
line[2].value 期望结果
line[1].value 邓肯
line[2].value 蒂姆
line[1].value 乔丹
line[2].value 迈克尔
line[1].value 库里
line[2].value 斯蒂芬
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
line[1].value 搜索词
line[2].value 期望结果
line[1].value 邓肯
line[2].value 蒂姆
line[1].value 乔丹
line[2].value 迈克尔
line[1].value 库里
line[2].value 斯蒂芬
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
邓肯 蒂姆
乔丹 迈克尔
库里 斯蒂芬

最后运行的脚本:

data_drivern_by_excel.py:

#encoding=utf-8
from selenium import webdriver
import unittest,time
import logging,traceback
import ddt
from ExcelUtil import ParseExcel
from selenium.common.exceptions import NoSuchElementException

#初始化日志对象
logging.basicConfig(
#日志级别
level=logging.INFO,
#日志格式
#时间、代码所在文件名、代码行号、日志级别名称、日志信息
format=‘%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s’,
#打印日志的时间
datefmt=‘%a,%Y-%m-%d %H:%M:S’,
#日志文件存放的目录(目录必须存在)及日志文件名
filename=‘d:\test\0627\report.log’,
#打开日志文件的方式
filemode=‘w’
)

excelPath=u"d:\test\0627\测试数据.xlsx"
sheetName=u"搜索数据表"
#创建ParseExcel类的实例对象
excel=ParseExcel(excelPath,sheetName)

#数据驱动装饰器
@ddt.ddt

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
的资料的朋友,可以添加V获取:vip1024b (备注软件测试)**
[外链图片转存中…(img-JdNsrKH3-1713346871518)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

转载请注明出处或者链接地址:https://www.qianduange.cn//article/6875.html
标签
评论
发布的文章

String转Json的几种方式

2024-05-09 11:05:04

iOS ------ JSONModel源码

2024-05-09 11:05:02

java去除 json 中的 \n, \t, \r

2024-05-09 11:05:57

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!