Selenium(Python) ddt读取Excel文件数据驱动

首先,

引入xlrd模块:

 

ExcelDDT.py:

import unittest
from time import sleep

from ddt import ddt, data
from selenium import webdriver
from xlrd import open_workbook


def getExcelTestData():
openExcelFile = open_workbook("./ExcelTestData.xlsx")
# 打开Excel文件
getSheet = openExcelFile.sheet_by_name("Sheet1")
# 获取工作表
rowNumber = getSheet.nrows
# 获取行数
dataList = []
# 数据List
for i in range(1, rowNumber):
# 从第二行开始遍历每一行
dataList.append(getSheet.row_values(i))
# 把每个单元格的数值存放到dataList中
return dataList


@ddt
# ddt驱动
class MyTestCase(unittest.TestCase):

def setUp(self):
self.driver = webdriver.Firefox()
self.base_url = "https://www.baidu.com/"
self.driver.get(self.base_url)
self.driver.maximize_window()
sleep(2)

@data(*getExcelTestData())
# 传递数据
def test_something(self, data):
searchTerm, searchResult = tuple(data)
driver = self.driver
driver.find_element_by_xpath(".//*[@id='kw']").send_keys(searchTerm)
driver.find_element_by_xpath(".//*[@id='su']").click()
sleep(2)
responseText = driver.find_element_by_xpath(".//*[@id='1']/h3/a").text
self.assertEqual(responseText, searchResult)

def tearDown(self):
self.driver.close()
self.driver.quit()

if __name__ == '__main__':
unittest.main()


ExcelTestData.xlsx文件:

 

 

转载于:https://www.cnblogs.com/yjlch1016/p/8489111.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值