IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> Selenium针对多选动态菜单分类,实现定位控制解决办法 -> 正文阅读

[开发测试]Selenium针对多选动态菜单分类,实现定位控制解决办法

Selenium针对多选动态菜单分类,实现定位控制解决办法

背景

关于Selenium通过控制谷歌浏览器实现WebUI的自动化测试,当选中分类列表时,由于具体的分类内容是前端点击输入框后,根据后端实时查询返回数据生成的html,其对应的span网页时一直在变化的,且是三级表单选择分类

注意:本案例代码由于涉及公司机密,因此本案例提供的代码是无法直接跑通的,本案例主要是提供一个解决办法的思路,仅供参考
算法分类案例图

解决办法

三级表单元素必须鼠标悬浮一级分类后,第二级分类才显示,鼠标悬浮在二级分类上,三级分类才显示,因此其span元素所对应的标签是动态的,话不多说,直接上代码
当选择“复制XPath”时,第一次span元素对应的Xpath路径为:
//[@id=“cascader-menu-2145-2-3”]/span
第二次span元素对应的Xpath路径为:
//
[@id=“cascader-menu-8179-2-1”]/span
你会发现当选择“复制XPath”时,其对应的XPath地址一直在变化,导致定位时找不到该元素
当采用“复制完整XPath”地址时,其对应的XPath地址每次打开的地址是不变的,都是
/html/body/div[4]/div[1]/div[1]/div[1]/ul/li/span
其根据html表结构顺序进行定位的,这种相对顺序一般是没有问题的,具体复制XPath地址的方法如下图所示:
在这里插入图片描述

from selenium import webdriver
from selenium.webdriver.chrome.service import Service
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import Select
from selenium.webdriver.common.action_chains import *
from selenium.webdriver.support.wait import WebDriverWait
wd = webdriver.Chrome(r'F:\WebUI\chromedriver.exe')
# 调用WebDriver 对象的get方法 可以让浏览器打开指定网址
# 进入登录界面
wd.get('http://')#具体根据自己网址进行选择
element1 = wd.find_element_by_xpath('//*[@id="app"]/div/div[2]/section/div/div[2]/div/div[2]/form/div[11]/div[1]/div/div/div/input').click()#选中输入框属性,点击输入框后弹出分类一级列表
FenLei_span = wd.find_element_by_xpath("/html/body/div[4]/div[1]/div[1]/div[1]/ul/li/span")
#选择Xpath时,需复制“完整的Xpath路径”
time.sleep(2)
webdriver.ActionChains(wd).move_to_element(FenLei_span).perform()#鼠标悬浮在第一级分类上(“算法超市”),同时显示第二级分类列表
# webdriver.ActionChains(wd).click_and_hold(FenLei_span).perform()
TongYong_span = wd.find_element_by_xpath("/html/body/div[4]/div[1]/div[2]/div[1]/ul/li[1]/span")#选择Xpath时,需复制第二级分类的“完整的Xpath路径”
# wd.implicitly_wait(10)
time.sleep(2)
webdriver.ActionChains(wd).move_to_element(TongYong_span).perform()#鼠标悬浮在第二级分类上(“通用算法”),同时显示第三级分类列表
XinXi_span = wd.find_element_by_xpath("/html/body/div[4]/div[1]/div[3]/div[1]/ul/li[2]/span")#选择Xpath时,需复制第三级分类的“完整的Xpath路径”
print(XinXi_span.text)
wd.implicitly_wait(10)
# time.sleep(5)
webdriver.ActionChains(wd).move_to_element(XinXi_span).perform()#鼠标悬浮在第三级分类上(“信息查询类”)
wd.find_element_by_xpath("/html/body/div[4]/div[1]/div[3]/div[1]/ul/li[2]/span").click()
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-18 18:12:40  更:2022-04-18 18:12:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 0:47:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码