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

接招吧! selenium环境+元素定位大法

selenium 与 webdriver

Selenium 是一个用于 Web 测试的工具,测试运行在浏览器中,就像真正的用户在手工操作一样。支持所有主流浏览器

WebDriver 就是对浏览器提供的原生API进行封装,使其成为一套更加面向对象的Selenium WebDriver API。

使用这套API可以操控浏览器的开启、关闭,打开网页,操作界面元素,控制Cookie,还可以操作浏览器截屏、安装插件、设置代理、配置证书等

环境搭建

1、为 Python 安装 selenium模块,pip install selenium

2、下载对应浏览器驱动 

Chromedriver

使用 selenium 访问百度并搜索

反爬虫设置

ui 自动化操作流程

选择界面元素

根据元素的特征:ID,Name,Class,Tag,等

根据元素特征和关系:css,xpath

操作界面元素

输入操作:点击、输入文字、拖拽等

输出操作:获取元素的各种属性

根据界面上获取的数据进行分析和处理

元素定位大法

find_element_by_id:通过ID进行匹配查找,只返回匹配到的一个元素

find_element_by_name:通过name进行匹配查找,只返回匹配到的一个元素

find_element_by_xpath:通过xpath进行匹配查找,只返回匹配到的一个元素

find_element_by_link_text:通过链接内容进行匹配查找,只返回匹配到的一个元素

find_element_by_partical_link_text:通过部分链接内容进行匹配查找,只返回匹配到的一个元素

find_element_by_tag_name:通过标签名称进行匹配查找,只返回匹配到的一个元素

find_element_by_class_name:通过class名称进行匹配查找,只返回匹配到的一个元素

find_element_by_css_selector:通过CSS选择器进行匹配查找,只返回匹配到的一个元素

值得注意的是,上面方法只会匹配查找只会获取第一个元素。除了上面这些查找单个元素的方法之外,Selenium还定义查找多个元素的方法:

find_elements_by_name:通过name进行匹配查找,返回所有匹配到的元素列表

find_elements_by_xpath:通过xpath进行匹配查找,返回所有匹配到的元素列表

find_elements_by_link_text:通过链接内容进行匹配查找,返回所有匹配到的元素列表

find_elements_by_partical_link_text:通过部分链接内容进行匹配查找,返回所有匹配到的元素列表

find_elements_by_tag_name:通过标签名称进行匹配查找,返回所有匹配到的元素列表

find_elements_by_class_name:通过class名称进行匹配查找,返回所有匹配到的元素列表

find_elements_by_css_selector:通过CSS选择器进行匹配查找,返回所有匹配到的元素列表

注意:

1、根据 class_name 进行定位的时候,有时候会遇到复合类,也就是 class 属性中间有空格,class 属性比较特殊,class属性中间的空格是间隔符号,表示的是一个元素有多个class的属性名称,此时元素定位的时候任取一个即可(不保证唯一定位)

2、selenium 没有提供判断元素是否存在的功能,所以当你需要判断一个元素存不存在的时候,直接定位可能会报错。我们可以去匹配一个元素列表,列表为空则元素不存在,列表不为空则元素存在

技巧,在进行元素定位的时候,有时会遇到一些特别难以定位的元素,此时你可以使用下边这种模式,分步骤定位,一步步缩小定位范围

  1. ele = driver.find_elements_by_xpath("//div[@id='category-block']//ol/li")

  2. b = ele.find_elements_by_xpath('.//li[@class=\'subcate-item\']//span')

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

  1. 文档获取方式:

  2. 加入我的软件测试交流群:680748947免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

相关文章:

  • TCP重传机制详解——03DSACK
  • jvm高级面试题-2024
  • 如何在Appium中使用AI定位
  • yarn安装包时报错error Error: certificate has expired
  • IDEA2023版本整合SpringBoot热部署
  • GEE训练——如何实现单景影像边界的提取以sentinel和Landsat数据为例(栅格转矢量)
  • github加速神器!解决github巨慢的问题,并且能够加速下载!另外推荐GitKraken -- 超好用的 Git 可视化工具
  • 数字孪生项目中实时数据驱动多节相连车厢沿轨道运行
  • SEO 的未来:GPT 和 AI 如何改变关键词研究
  • 蓝桥杯刷题计划-洛谷-持续更新
  • 价格才不是小米汽车的最大“杀器”
  • 阿里云对象存储OSS入门
  • JavaSE day14笔记
  • vscode添加gitee
  • 贪心算法相关题目
  • 「前端」从UglifyJSPlugin强制开启css压缩探究webpack插件运行机制
  • 2017年终总结、随想
  • 30天自制操作系统-2
  • 4. 路由到控制器 - Laravel从零开始教程
  • avalon2.2的VM生成过程
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • iOS帅气加载动画、通知视图、红包助手、引导页、导航栏、朋友圈、小游戏等效果源码...
  • Java超时控制的实现
  • js递归,无限分级树形折叠菜单
  • Logstash 参考指南(目录)
  • mongo索引构建
  • PAT A1120
  • React的组件模式
  • ubuntu 下nginx安装 并支持https协议
  • 表单中readonly的input等标签,禁止光标进入(focus)的几种方式
  • 测试开发系类之接口自动化测试
  • 反思总结然后整装待发
  • 后端_ThinkPHP5
  • 你不可错过的前端面试题(一)
  • 深入 Nginx 之配置篇
  • 我从编程教室毕业
  • 在Mac OS X上安装 Ruby运行环境
  • ​ 无限可能性的探索:Amazon Lightsail轻量应用服务器引领数字化时代创新发展
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • #define、const、typedef的差别
  • #vue3 实现前端下载excel文件模板功能
  • (solr系列:一)使用tomcat部署solr服务
  • (二)换源+apt-get基础配置+搜狗拼音
  • (附源码)计算机毕业设计ssm基于Internet快递柜管理系统
  • (过滤器)Filter和(监听器)listener
  • (一)硬件制作--从零开始自制linux掌上电脑(F1C200S) <嵌入式项目>
  • (转)Windows2003安全设置/维护
  • ***详解账号泄露:全球约1亿用户已泄露
  • .NET DataGridView数据绑定说明
  • .NET 自定义中间件 判断是否存在 AllowAnonymousAttribute 特性 来判断是否需要身份验证
  • .NET6使用MiniExcel根据数据源横向导出头部标题及数据
  • @Builder用法
  • @SuppressWarnings注解
  • [ 蓝桥杯Web真题 ]-布局切换
  • [2009][note]构成理想导体超材料的有源THz欺骗表面等离子激元开关——