1、excel中數據(注意:數據是純數字時,要將其設置成文本)
2、讀取excel文件函數封裝
文件名稱:read_excel.py
import xlrd class ReadExcel(): def __init__(self, excelPath, sheetName="Sheet1"): self.data = xlrd.open_workbook(excelPath) self.table = self.data.sheet_by_name(sheetName) # 獲取第一行作為key值
self.keys = self.table.row_values(0) # 獲取總行數
self.rowNum = self.table.nrows # 獲取總列數
self.colNum = self.table.ncols def dict_data(self): if self.rowNum <= 1: print("總行數小於1") else: r = [] j=1
for i in range(self.rowNum-1): s = {} # 從第二行取對應values值
values = self.table.row_values(j) for x in range(self.colNum): s[self.keys[x]] = values[x] r.append(s) j+=1
return r if __name__ == "__main__": filepath = "D://gmy//seleniumTest//sel_test//cases//ddt_data.xlsx" data = ReadExcel(filepath) print(data.dict_data())
3、測試用例
文件名稱:test_readexcel.py
import ddt import unittest from common.read_excel import ReadExcel import os from selenium import webdriver from common.base import Base curpath = os.path.dirname(os.path.realpath(__file__)) excelpath = os.path.join(curpath,"login.xlsx") print(excelpath) data = ReadExcel(excelpath) testdata = data.dict_data() @ddt.ddt class Test(unittest.TestCase): # 定位手機號
username = ("name", "loginName") # 定位密碼
psw = ("name", "loginPassWord") # 定位登錄按鈕
loginbutton = ("id", "loginBtn") # 定位提示信息
message = ("className", "toast-message") @classmethod def setUpClass(cls): cls.driver = webdriver.Firefox() cls.login = Base(cls.driver) def setUp(self): self.driver.get("url地址") def tearDown(self): #清空cookies
self.driver.delete_all_cookies() @classmethod def tearDownClass(cls): cls.driver.quit() @ddt.data(*testdata) def test_login(self,data): '''測試登錄{0}''' username = data['user'] password = data['psw'] exp = data['exp'] # 輸入手機號
self.login.send(self.username, username) # 輸入密碼
self.login.send(self.psw, password) # 點擊登錄按鈕
self.login.click(self.loginbutton) # 獲取結果
result = self.login.find(self.message).text print("我是結果:", result) self.assertEqual(result, exp) if __name__ == '__main__': unittest.main()
base.by 文件查看selenium+python自動化測試--登錄
4、運行結果
最后,附帶讀取excel函數封裝參考地址:https://www.cnblogs.com/yoyoketang/p/6701950.html