当前位置: 首页 > news >正文

python + selenium 初步实现数据驱动

如果在进行自动化测试的时候将测试数据写在代码中,若测试数据有变,不利于数据的修改和维护。但可以尝试通过将测试数据放到excel文档中来实现测试数据的管理。

示例:本次涉及的项目使用的12306 selenium 重构------三层架构
excel文件数据如图所示:
在这里插入图片描述
整体项目代码结构如图所示:
在这里插入图片描述
function.py 代码如下(基础代码):

# coding = utf-8'''基础常用方法'''from datetime import date,timedelta
from selenium import webdriver
from selenium.webdriver.common.by import By
import xlrd
import logging# 将driver设置为全局变量
driver = webdriver.Chrome()def return_driver():'''函数return_driver()的功能是返回driver对象:return:driver对象'''return driverdef open_base_site(url):'''打开网页:param url:要打开的网页地址:return:'''driver.get(url)def max_window():'''浏览器窗口最大化:return:'''driver.maximize_window()def close_driver():'''关闭浏览器:return:'''driver.quit()# 以下为定义函数部分,其目的是返回今天后的第n天后的日期,格式为“2022-03-28”
def date_n(n):return str((date.today() + timedelta(days=int(n))).strftime('%Y-%m-%d'))def id(element):'''根据元素id属性值来返回元素定位语句。:param element: id属性值:return:按照id属性来定位元素的语句'''return driver.find_element(By.ID, element)def xpath(element):'''使用xpath定位元素:param element::return:按照xpath方式来定位元素的语句'''return driver.find_element(By.XPATH, element)def read_excel(excleName, sheetName):'''按行读取excel:param excleName: excel文件名:param sheetName: sheet名称:return: 列表形式'''wb = xlrd.open_workbook(excleName)sheet = wb.sheet_by_name(sheetName)data = []for row in range(sheet.nrows):data.append(sheet.row_values(row))return datadef filelog(logName):'''文件日志器:return: 日志器'''# 创建日志器logger = logging.getLogger()# 设置日志器输出级别logger.setLevel(logging.DEBUG)# 创建格式器fmt = '%(asctime)s %(filename)s %(lineno)d %(levelname)s %(message)s'format = logging.Formatter(fmt=fmt, datefmt='%Y-%m-%d %H:%M:%S %a')# 创建文件处理器fileHandler = logging.FileHandler(logName + '.log', mode='a', encoding='utf-8')# 处理器添加格式器fileHandler.setFormatter(format)# 日志器添加文件处理器logger.addHandler(fileHandler)# 返回日志器return logger

search_tickets.py 的代码如下:

# coding = utf-8from functions import return_driver, open_base_site,max_window,date_n,xpath,iddef search_tickets(from_station, to_station, n, url):'''搜索车次:param from_station: 出发城市:param to_station: 到达城市:param n: 一个数字,如1表示选择明天的车票,2表示选择后台的车票:param url: 要访问的网站地址:return:'''# tomorrow变量:出发日期tomorrow = date_n(n)# 打开浏览器driver = return_driver()# 打开网站open_base_site(url)# 设置窗口最大化max_window()# 输入出发城市xpath('//input[@id="fromStationText"]').click()xpath('//input[@id="fromStationText"]').send_keys(from_station)xpath('//div[@id="citem_2"]').click()# 输入到达城市xpath('//input[@id="toStationText"]').click()xpath('//input[@id="toStationText"]').send_keys(to_station)xpath('//div[@id="citem_1"]').click()# 输入出发时间id('train_date').clear()id('train_date').send_keys(tomorrow)# 点击查询id('search_one').click()# 切换到新窗口driver.switch_to.window(driver.window_handles[1])# 点击弹窗确认按钮xpath('//a[@id="qd_closeDefaultWarningWindowDialog_id"]').click()# 点击D2244车次的预订xpath('//tr[starts-with(@id,"ticket_76000D22440N_01_06")]/td/a').click()

login.py文件代码如下:

# coding = utf-8from functions import iddef login(username, password):'''账号登录:param username: 用户名:param password: 密码:return:'''# 输入用户名id('J-userName').send_keys(username)# 输入密码id('J-password').send_keys(password)

测试代码文件test_booking_tickets.py 如下:

# coding = utf-8from search_tickets import search_tickets
from login import login
from functions import close_driver, read_excel, filelog
from time import sleep# 搜索火车票列表
log = filelog('12306')
log.info('读取excel文件')
data = read_excel('testdata.xlsx', 'city')
print(data)
log.info('开始搜索火车票')
search_tickets(data[0][0], data[0][1], 1, 'https://www.12306.cn/index/')
log.info('搜索火车票结束')
sleep(2)
# 登录
log.info('输入用户名密码开始登录')
login(data[1][0], data[1][1])
log.info('登录成功')
sleep(2)
# 关闭浏览器
log.info('关闭浏览器')
close_driver()
http://www.lryc.cn/news/279380.html

相关文章:

  • 数字孪生+可视化技术 构建智慧新能源汽车充电站监管平台
  • 微信小程序开发学习笔记《11》导航传参
  • BikeDNA(七)外在分析:OSM 与参考数据的比较1
  • KY43 全排列
  • UltraScale 和 UltraScale+ 生成已加密文件和已经过身份验证的文件
  • 2023年全国职业院校技能大赛软件测试赛题—单元测试卷②
  • 极兔单号查快递,极兔快递单号查询,筛选出途经指定城市的单号
  • [redis] redis高可用之持久化
  • 云原生 微服务 restapi devops相关的一些概念说明(持续更新中)
  • 初学unity学习七天,经验收获总结
  • hcip实验2
  • js:使用canvas画一个半圆
  • 1.框架介绍项目环境配置与项目启动!
  • LeetCode算法题解:螺旋矩阵
  • 【Java 设计模式】设计原则之开放封闭原则
  • 数据分析求职-知识脑图
  • SQL-修改数据
  • Rockchip | FIQ-Debugger调试工具
  • 第二百六十三回 给geolocator插件提交问题
  • 分组背包问题
  • WinForm 中Label自动换行 解决方法
  • 【蓝桥杯软件赛 零基础备赛20周】第7周——二叉树
  • SpringBoot+SSM项目实战 苍穹外卖(12) Apache POI
  • Maven 基础总结篇
  • MySQL的导入导出及备份
  • 【机器学习】常见算法详解第2篇:K近邻算法各种距离度量(已分享,附代码)
  • @KafkaListener指定kafka集群
  • 什么是算法的空间复杂度?
  • WebDav协议相关软件@简单配置局域网内的http和WebDav服务器和传输系统
  • 自定义数据实现SA3D