Selenium 驱动配置 和 元素定位

目录

驱动配置

元素定位

By类普通参数方法

CSS选择器参数方法

By类xpath参数方法


驱动配置

                                                  

//新建chrome浏览器驱动配置
ChromeOptions options = new ChromeOptions();//添加参数,允许远程访问
options.addArguments("--remote-allow-origins=*");//新建WebDriver浏览器驱动
WebDriver driver = new ChromeDriver(options);

元素定位

                                                  

Webdriver提供了三类定位元素的方法,包括:

  • By类常用方法
  • CSS选择器方法
  • By类xpath方法

不管用哪种方式,必须保证页面上该属性的唯一性。


所有的定位方法都是 findElement() 方法,只是参数不同。

除 findElement() 方法外,还有 findElements() 方法。前者返回单个元素,后者返回元素集合。


By类普通参数方法

                                                  

方法描述参数
findElement(By.id("属性值"))通过元素的 id 属性值来定位元素对应的id属性值
findElement(By.name("属性值"))通过元素的 name 属性值来定位元素对应的name值
findElement(By.className("类名"))通过元素的 class 名来定位元素对应的class类名
findElement(By.tagName("标签名"))通过元素的 tag 标签名来定位元素对应的标签名
findElement(By.linkText("文本"))通过元素标签对之间的文本信息来定位元素文本内容
findElement(By.partialLinkText("部分文本"))通过元素标签对之间的部分文本信息来定位元素部分文本内容

CSS选择器参数方法

                                                  

  • id选择器:findElement(By.cssSelector("#kw")

  • name定位:findElement(By.cssSelector("[name=wd]")

  • class选择器:findElement(By.cssSelector(".s_ipt")

  • 标签选择器:findElement(By.cssSelector("div")


使用CSS选择器作为参数时,可以根据CSS的层级定位进行输入,如:

        findElement(By.cssSelector("html > body > form > span > input"))

        findElement(By.cssSelector("span.soutu-btn> input#kw"))


By类xpath参数方法

                                                  

xpath 常用符号、格式和方法
符号说明
*通配符
/绝对路径
//相对路径
[下标]索引,从1开始
标签名[@属性名=‘属性值’]属性值表示格式
[text()='文本']文本定位
[contains(text(),'部分文本')]部分文本定位

部分定位方法示例:

  • id定位:findElement(By.xpath("//*[@id='kw']"))

  • name定位:findElement(By.xpath("//*[@name='wd']"))

  • class属性定位:findElement(By.xpath("//input[@class='s_ipt']"))

  • 定位绝对路径:findElement(By.xpath("/html/body/form/span/input"))

  • 定位相对路径:findElement(By.xpath("//form[@id='form']/span/input"))

  • 索引定位:findElement(By.xpath("/form/span[1]/input"))

  • 组合属性定位:findElement(By.xpath("//input[@id='kw' and @name='wd']"))

  • 文本定位:findElement(By.xpath("//span[text()='文本']"))

  • 部分文本定位:findElement(By.xpath("//span[contains(text(),'部分文本')]"))


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/767857.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Transformer的前世今生 day03(Word2Vec、如何使用在下游任务中)

前情回顾 由上一节,我们可以得到: 任何一个独热编码的词都可以通过Q矩阵得到一个词向量,而词向量有两个优点: 可以改变输入的维度(原来是很大的独热编码,但是我们经过一个Q矩阵后,维度就可以控…

day29|leetcode|C++|491. 非递减子序列|46. 全排列|47. 全排列 II

Leetcode 491. 非递减子序列 链接:491. 非递减子序列 thought: 设 stack 中最后一个值的位置为 last。如果 stack 为空,则 last -1。 设当前正在处理的位置为 pos。如果在 nums 的子区间 [last1, pos) 中,存在和 nums[pos] 相同的值&…

Kafka broker

1. zk中存储的kafka信息 /kafka/brokers/ids存储了在线的broker id。 /kafka/brokers/topics/xxx/partitions/n/state存储了Leader是谁以及isr队列 /kafka/controller辅助Leader选举,每个broker都有一个controller,谁先在zk中注册上,谁就辅助…

Autosar MCAL配置——Fls

文章目录 一、FLS基础知识二、达芬奇配置2.1 创建Fls模块2.2 FlsGeneralFlsDataFlash2.3 FlsConfigSet0FlsSector2.4 FlsPublishInfomation一、FLS基础知识 主要提供对Flash的读,写,擦相关操作服务;如果底层硬件支持的话,也提供一些配置接口来设置擦/写保护功能。 flash操…

低成本养号降低封号风险,这种方式你试过了吗?

众所周知,对于那些主要依赖海外社交媒体平台(如Facebook脸书、推特X、Instagram等)进行引流和投广、谷歌上架应用等拓展海外业务、主要赚海外money的朋友们而言,账号一旦被封,就会严重影响业务进程,甚至可能…

腾讯云服务器多少钱一年?价格表新鲜出炉(2024)

腾讯云服务器多少钱一年?61元一年起。2024年最新腾讯云服务器优惠价格表,腾讯云轻量2核2G3M服务器61元一年、2核2G4M服务器99元一年可买三年、2核4G5M服务器165元一年、3年756元、轻量4核8M12M服务器646元15个月、4核16G10M配置32元1个月、312元一年、8核…

【研究僧总结】回顾第1095个创作日

目录 前言一. 机缘二. 日常三. 展望 前言 感觉刚过1024不久,现在又来个1095创作日 一. 机缘 研究僧一直在找平台做笔记,方便之后的回顾总结,也让各位网友见证你我的成长,相互学习 止不住的写文止不住的成长,大家共同…

Docker 之 数据卷

目录 1. 数据卷是什么 1.1 运行一个带有容器卷存储功能的容器实例 2.能干什么 3. 容器卷案例 3.1 宿主机vs容器之间映射添加容器卷 3.1.1 命令添加: 3.1.2 查看数据卷是否挂载成功 3.1.3 容器和宿主机之间数据共享 3.2 读写规则映射添加说明 3.2.1 读写&…

java系统部署到Linux

1、安装java 1.8JDK 卸载Open JDK 首先,我们先检查系统是否自带了 JDK。输入命令 java -verison批量删除 rpm -qa | grep java | xargs rpm -e --nodeps下载并安装JDK 我们在 user 目录下建立一个新的 java文件夹,用来存放 JDK文件。 jdk下载地址 …

快速上手 Elasticsearch:Docker Compose 部署详解

最近面试竞争日益激烈,Elasticsearch作为一款广泛应用的中间件,几乎成为面试中必考的知识点。最近,AIGC也备受关注,而好多的AI项目中也采用了Elasticsearch作为向量数据库,因此我们迫切希望学习Elasticsearch。对于学习…

全球首位AI程序员Devin的诞生及其对程序员职业未来的影响

写在开头 在人工智能(AI)的浪潮下,全球首位AI程序员Devin的出现,无疑为软件开发领域带来了前所未有的变革。Devin不仅是一个编程工具,更是一个标志性的里程碑,预示着AI技术在编程领域的应用将更加广泛和深…

Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别?

Docker简介 前言 前端有必要学习Docker吗?有!!不仅要学Docker,还要学习Kubernetes (K8s),Jenkins 那问题来了,Docker,k8s,jenkins到底要先学习那个呢?当然是Docker 总结来说,先学习…

typescript关键知识点总结(一)

一 聊聊typescript的核心原理 TypeScript 是一种基于 JavaScript 的强类型编程语言,它使得在前端项目开发过程中更加严谨且流畅,一定程度上保证了大型前端项目程序的健壮性。 但是 TypeScript 并不可以直接运行,而是需要转换成 JavaScript 代码才可以在 Node.js 或浏览器环…

C++初阶:STL容器list的使用与初版自实现

目录 1. list的接口与使用1.1 默认成员函数1.2 迭代器与容量相关成员函数1.3 存储数据操作相关成员函数1.4 其他list操作成员函数 2. list的自实现2.1 list的自实现功能2.2 list的结点结构2.3 list的迭代器2.3 list的结构2.4 list迭代器的运算符重载2.5 list的成员函数 3. cons…

双指针(滑动窗口)-算法刷题

一.移动零(. - 力扣(LeetCode)) 算法思想 : 设置两个指针left,right,将数组分为三块[0,left]为不为0的元素,[left1,right-1]为0元素,[right,num.size()-1]为未扫描的区域&#xff0c…

第四百二十二回

文章目录 1. 概念介绍2. 思路与方法2.1 实现思路2.2 实现方法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"自定义标题栏"相关的内容,本章回中将介绍自定义Action菜单.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 我们在这里提到的…

从零开始一步一步掌握大语言模型---(3-词表示-word representation)

词表示和语言模型 词表示是指把自然语言里面最基本的单位,也就是词,将其转换为机器所能理解的过程。 词表示的目的: 1. 计算词之间的相似度; 2. 推理词之间的关系。 1.最早是如何表示一个词呢? 设目标词是X&#…

day3-QT

1>使用手动连接,将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函。将登录按钮使用qt5版本的连接到自定义的槽函数中,在槽函数中判断ui界面上输入的账号是否为"admin",密码是…

JS操作元素的内容

对象.innerText 属性 对象.innerHTML 属性 <body><div classbox>文字</div><script>//首先获取元素const box document.querySelector(.box)console.log(box.innerText)</script> </body> 1.元素innerText属性 将文本内容添加到标签任…

【Redis知识点总结】(六)——主从同步、哨兵模式、集群

Redis知识点总结&#xff08;六&#xff09;——主从同步、哨兵模式、集群 主从同步哨兵集群 主从同步 redis的主从同步&#xff0c;一般是一个主节点&#xff0c;加上多个从节点。只有主节点可以接收写命令&#xff0c;主节点接收到的写命令&#xff0c;会同步给从节点&#…