不断学习的测试小姐姐
Selenium 还可以通过CSS定位
selenium定位元素的方法有很多种,像是通过id、name、class_name、tag_name、link_text等等,但是这些方法具有局限性,比如id,不一定每个元素都有id属性,真正需要熟练掌握的是通过xpath和css定位
Selenium通过Xpath定位
上篇文章学习了Xpath定位的一些概念,一些函数,这次学习下方法
第一种方式,通过绝对路径方式定位
By.xpath(“html/body/div/form/input”)
第二种方式,通过相对路径方式定位
By.xpath("//input")
第三种方式,通过元素索引定位
By.xpath("//input[4]")
第四种方式,使用xpath属性定位
By.xpath("//input[@id=‘kw’]")
By.xpath("//input[@type=‘XXX’ and @name=‘wd’]")
第五种方法,使用部分属性值匹配
starts-with匹配一个属性开始位置的关键字
contains 匹配一个属性值中包含的字符串
By.xpath("//input[start-with(@id,‘k’)
By.xpath("//input[ends-with(@id,‘w’)
By.xpath("//input[contains(@id,‘kwkw1’)]")
第六种方法,使用xpath轴
什么是xpath轴:轴可定义相对于当前节点的节点集
这里举例,更容易理解一些
具体使用方法示例为:parent::div,即轴名称::标签名
Parent
parent 选取当前节点的父节点,也就是当前节点上一级节点
//div[contains(text(),‘产证地址’)]/parent::td
前半段//div[contains(text(),‘产证地址’)]为找到内容包含产证地址的div节点
然后它的上一级节点 parent::td
child
child 选取当前节点的子节点,也就是当前节点的下一级节点
示例://td[@width=‘50%’]//child::div
前半段//td[@width=‘50%’] 为找到属性width为50%的td节点
然后它的下一级节点child::div
其实还有一些我也在学习中,后面用到了在补充
一些常用到的搭配轴名称使用的词注解
starts-with 匹配一个属性开始位置的关键字
contains 匹配一个属性值中包含的字符串
text() 匹配的是显示文本信息
//input[starts-with(@name,‘name1’)] 查找name属性中开始位置包含’name1’关键字的页面元素
//input[contains(@name,‘na’)] 查找name属性中包含na关键字的页面元素
.// 和//的区别
//是指从全文上下文中搜索//后面的节点
.// 中.表示当前节点,.//表示从当前节点之后的子节点中查找