温馨提醒
如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢
本文最后更新于2023年11月16日,已超过 180天没有更新
一、XPath定位
定位 | 说明 |
//ul/* | ul的所有子元素 |
//input[2] | 第2个input元素 |
//input[last() | 最后一个input元素 |
input[position()< 3] | 前2个input元素 |
//input[@value] | 有value属性的input元素 |
//input[@name=‘password’ and @pwd=‘123456’] | 属性name的值等于password并且属性pwd的值等于123456的input元素 |
//ul/*[5] | ul的第五个子元素 |
//*[text()=‘Heading’ | 任意包含Heading文本的元素 |
//input[@*=‘SYS123456’] | 任意属性的值为SYS123456 |
1、find_element_by_xpath("//input[@id='input']") #@后跟属性,可以是任何属性语法://标签名[@属性名=属性值]1、使用标签名+节点属性定位
2、组合元素索引(下标)定位
find_element_by_xpath("//*[@id='J_login_form']/*/*/input[2]")
3、通过部分属性值匹配
语法://标签名[contains(@属性名,部分属性值)]、//标签名[starts-with(@属性名,部分属性值)]、//标签名[ends-with(@属性名,部分属性值)] a.starts-with 例子: //input[starts-with(@id,'ctrl')] 解析:匹配以 ctrl开始的属性值 b.ends-with 例子://input[ends-with(@id,'_userName')] 解析:匹配以 userName 结尾的属性值 c.contains() 例子://input[contains(@id,'userName')] 解析:匹配含有 userName 属性值
4、使用文本内容匹配
函数:text() 语法:文本全部匹配://标签名[text()=文本内容]
文本部分匹配-包含://标签名[contains(text(),部分文本内容)]
driver.find_element_by_xpath("//a[text()="退出"]")` #文本全部匹配 driver.find_element_by_xpath("//a[contains(text(),"出")])` #文本部分匹配
5、使用轴定位表达式
* ancestor:祖先节点,包括父节点 * parent:父节点 * child:子节点 * descendant:所有后代(儿子、孙子、曾孙子...) * preceding:当前元素节点标签之前的所有节点(HTML页面之前的) * preceding-sibling:当前元素节点标签之前的所有兄弟节点(同级) * following:当前元素节点标签之后的所有节点 * following-sibling:当前元素节点标签之后的所有兄弟节点(同级) * 使用语法:轴名称::节点名称前后的定位与之前一致,用/隔开即可 * //div//table/td/preceding::td/following-sibling::a//[contains(text(),"课程")] #表示//div//table/td/路径前所有节点中找到节点名称为td的节点,向下同级下的一个兄弟节点包含文本课程。
二、XPath定位验证
1、验证XPath定位元素是否正确,可以在Google Chrome的elements或console中进行验证
在需要定位的页面,按F12后,切换至elements列下,按下Ctrl+f键,输入XPath表达式
1、在需要定位的页面,按F12后,切换至console列下,输入表达式。语法是:$x("your_xpath_selector")
2、表达式正确,元素定位正确时,会查找出该元素,如下图:
3、未定位准确,找不到该元素,查找结果为空,如图:
4、表达式不正确,无法正常识别情况,可能会有很多种错误,列举一个例子,如图:
原因:语法中括号里需要通过双引号括起来,如果XPath语句中有双引号,要改成单引号,不然只能解析到第一对双引号的内容。这也是需要特别注意的一点。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论0+