1、绝对定位
浏览器F12开启调试模式,鼠标右击复制xpath:
/html/body/div[1]/div[5]/div[1]/div[3]/div[12]/h3/a
此方法的缺点就很显然了,不想维护做噩梦的话就尽量不用这个。往下看
2、标签属性定位
比如定位到图中的<h3>小标题
’ //h3[@class=“t c-gap-bottom-small”]’
'//h3[@class="t c-gap-bottom-small"]/a'
属性定位,相对比较简单些,但要求当前页面此标签的属性具有唯一性,如果存在多个相同标签相同属性的,selenium就只会默认去触发第一个。具体格式为:
//标签[@属性=“对应属性值”]
标签里的任意属性都可以,但单个属性要具有唯一性!
3、标签属性组合定位
当存在单个属性与其他标签重复时就可采用组合定位的方法了。例如:
‘//div[@id=“1” and @class=“result-op c-container”]’
4、属性值模糊定位
有时标签内的属性值会很长,全部复制就不显简洁,这时就可以采用模糊定位的方法了。例如:
'//a[@href, "http://www.baidu.com/link?url="]'
5、文本值定位
标签中间存在字符串也可用来定位。例如:
'//a[contains(text(),"历史发展")]'
此字符串要也具有唯一性,不然也是默认第一个。
PS:字符串尽量从标签中复制过来,不要手写上去。
6、动态属性定位
若当页面出现动态的属性,以动态Id为例,一般变动就是其中的数字。
<div class="c-row" id="list_113652_word">
一般有三种处理方式:starts-with(),contains(),ends-with()
如字面意思:
starts-with:是id中以不变的部分字符串开头;
contains:是id中包含不变的部分字符串;
ends-with:是id中以不变的部分字符串结尾;
实例:
'//div[starts-with(@id,'list_')]'
'//div[contains(@id,'list_')]'
'//div[ends-with(@id,'_word')]'
以上都是一般可以定位的属性,当存在属性及其组合都不能定位时,可以通过上下节点进行定位,以下摘自网上搜索:
1、child:选取当前节点的所有子元素
2、parent:选取当前节点的父节点
3、descendant:选取当前节点的所有后代元素(子、孙等)
4、ancestor:选取当前节点的所有先辈(父、祖父等)
5、descendant-or-self:选取当前节点的所有后代元素(子、孙等)以及当前节点本身
6、ancestor-or-self:选取当前节点的所有先辈(父、祖父等)以及当前节点本身
7、preceding-sibling:选取当前节点之前的所有同级节点
8、following-sibling:选取当前节点之后的所有同级节点
9、preceding:选取文档中当前节点的开始标签之前的所有节点
10、following:选取文档中当前节点的结束标签之后的所有节点
11、self:选取当前节点
12、attribute:选取当前节点的所有属性
13、namespace:选取当前节点的所有命名空间节点
**
欢迎各位大佬小白加群群里面有很多资料你想要的我都有:656721740
**