id,name,class,xpath, css selector这些属性,你最偏爱哪一种,为啥

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了id,name,class,xpath, css selector这些属性,你最偏爱哪一种,为啥相关的知识,希望对你有一定的参考价值。

css selector不是什么属性吧。再说这些东西不是按需采用的吗,和偏爱没啥关系啊,能解决问题的属性就是需要的属性,再偏爱,解决不了问题有啥用 参考技术A 之前在传智播客接触过。Xpath、id。因为在经验丰富的情况下,我们可以直接手写xpath表达式,而不需要打开检查来定位元素。Id是因为在web自动化中是整个页面唯一的。我们可以放心使用而不必担心重复。关于这些属性的介绍黑马程序员社区有非常详细的,以及学习教程。本回答被提问者采纳

Selenium----Xpath定位

什么是Xpath

Xpath是XML的路径语言,就是通过元素的路径来查找这个标签元素

 

Xpath使用方法

先写//*代表定位页面下的所有元素

1、ID、Class、Name定位

#ID定位
 
//*[@id=kw]
 
#Class定位
 
//*[@class=class_name]
 
#Name定位
 
//*[@name=name]

2、如果没有ID、Class、Name,可以用属性定位

#@ 代表以属性定位,后面可以接标签中任意属性
 
//*[@other=attribute]

3、当属性重复时,通过标签过滤

#将 * 换位任意标签名,则可根据标签进行筛选
 
//input[@placeholder=用户名]

4、当标签也重复时,通过层级过滤 (找不到儿子,就找他的爸爸,实在不行,再找他爷爷)

#支持通过 / 进行层级递进,找到符合层级关系的标签
 
//form/div/input[@placeholder="用户名"]
 
#当层级都重复时,可以通过单个层级的属性进行定位
 
//form/div[@class=login-user]/input

5、一个元素它的兄弟元素跟它的标签一样,这时候无法通过层级定位到。因为都是一个父亲生的,多胞胎兄弟,这时可以用索引过滤

#通过索引,在List中定位属性,与python的索引有些差别,Xpath从1开始
 
//select[@name=city][1]/option[1]

6、如果上述方法都用了还是重复的话,就用Xpath提供的终极神器,逻辑运算定位。and 或 or

#通过and来缩小过滤的范围,只有条件都符合时才能定位到
 
//select[@name=city and @size=4 and @multiple="multiple"]
 
#or就相反了,只要这些筛选中,其中一个出现那么久匹配到了
 
//select[@name=city or @size=4]

 

以上是关于id,name,class,xpath, css selector这些属性,你最偏爱哪一种,为啥的主要内容,如果未能解决你的问题,请参考以下文章

Selenium----Xpath定位

Xpath使用方法

Selenium 使用 css、xpath、name、id (python) 找不到任何元素

11.Selenium元素的定位xpath表达式定位

python+selenium基础之XPATH定位

selenium定位方法