selenium自动化之xpath定位必会技能

版权声明:请注明原创地址 https://blog.csdn.net/xy_best_/article/details/84951468

相信写过ui自动化,对xpath定位感觉会特别亲戚,那么下面给大家分享些我们常常在写脚本时易忽略的一些小细节和技巧。
首先使用xpath定位时切忌

  • 不要使用带有空格的属性
  • 不要使用自动生成的id、class 等
  • 使用firebug会事半功倍
  • 定位时一定要找到唯一的属性要确保定位的唯一性,根据唯一的属性进行各种定位
  • 查看是否存在frame

Xptah定位
1、按F12打开控制台,点击箭头,指定到要定位的元素,需要关注的地方,是否在Top window中,若在frame中则需要先切换frame,调用切换frame的action即可
2、用contains关键字,定位代码如下:
//a[contains(text(),‘忘记密码’)],contains中的text()表示标签中的文本信息同时contains也支持@属性名称等如://a[contains(@id,’*****’)]等。
3、使用元素属性定位,定位代码如下:
//input[@id = ‘pass’],只要是该标签中存在的属性,理论上都可以使用(有些动态生成的属性无法使用,过长的属性也不推荐使用)例://input[@placeholder= ‘密码’]等。
4、使用层级定位,定位代码如下:
//form[@id = ‘login-form’]//input[@placeholder= ‘密码’],先定位该元素的父节点或祖先节点,再定位当前节点,中间以“//”连接。层级定位可以结合parent::、ancestor::灵活使用。
5、使用兄弟节点定位,定位代码如下:
//p[contains(text(),‘Dior会员登录’)]//following-sibling::ul[contains(@class,‘form-list’)],following-sibling::表示往下查找该元素的兄弟节点,preceding-sibling::表示往上查找该元素的兄弟节点。
6、最不推荐的定位方式,定位代码如下:
//*[@id=“login-form”]/div/div[2]/div[1]/ul,F12打开chrome浏览器的开发者工具,点击左上角的箭头并移到需要定位的元素,在html中右击>Copy>Copy XPath。
XPATH的几个常用函数
1、contains ():
//div[contains(@id,‘in’)] ,表示选择id中包含有’in’的div节点
2、text():
由于一个节点的文本值不属于属性,比如“baidu”,所以,用text():函数来匹配节点://a[text()=‘baidu’]
3、last():
函数位置定位
4、starts-with():
//div[starts-with(@id,‘in’)] ,表示选择以’in’开头的id属性的div节点
5、not()函数,表示否定
//input[@name=‘identity’ and not(contains(@class,‘a’))] ,表示匹配出name为identity并且class的值中不包含a的input节点。

猜你喜欢

转载自blog.csdn.net/xy_best_/article/details/84951468