上一篇借用xpath介绍了一下如何用绝对&相对路径定位,个人觉得xpath是selenium支持的定位方式中最有效的手段,它比id,name等属性定位强大灵活,而且又比同样强大的css selector的方式更接近自然语言容易理解。所以掌握了xpath对解决元素定位的困扰会有很大的帮助。今天就简单地介绍一下selenium中常用的一些xpath语法,有兴趣深入学习的可以参考w3school的教程。
选取xpath节点的方法有两种,通过沿着路径(path)或者步(step)来选取,先介绍一下沿着路径选取的语法。
下面来举几个例子来帮助理解
/htm/body/form/input: 在页面第一个div下第一个form的第一个input元素
../div:当前节点的父节点下的div元素
./div:当前节点下的div元素
./*: 当前节点下的所有元素
//div/span/a: 选取所有被div/span包裹的链接
//input[@class='btn']: 选取所有class为btn的input
//input[@class = 'btn' and @id='submit']: 选取所有class为btn且id为submit的input
//input[@class = 'btn'] | //input[@class='btn1']: 选取所有class为btn或btn1的input
以上的例子应该已经涵盖了大部分的使用场景,路径选取也是xpath在selenium里常用的方法。第二种用步来选取的方法我从来没用过,就简单介绍一下概念
路径选取的方法是从树状结构的由上而下按给出的路径去找到元素,而步的方法在当前节点的基础上通过节点之间的相对关系去选取到需要的元素,语法如下
轴名称::节点条件[谓语]
轴名称用来表示目标节点与当前节点的关系,例如父,子,兄弟等等。节点条件表示目标节点需要符合哪些条件。谓语是可选的,是在结果集中进一步筛选的一些方法。因为selenium用的不多,个人也没什么经验,更多的信息还请自己去寻找资料。