Xpath定位
 
验证xpath写的是否正确:
1、打开浏览器检查页面,Ctrl+F,把路径输入进去,如果可以定位到的位置只有一个,说明是对的
2、在需要定位的页面,按F12后,切换至console列下,输入表达式。语法 $x("path_selector")
 
最常用的归纳几点:
   @     用在标签的属性前,选取属性      //标签[@属性名=属性值]
    ..    选取当前节点的父节点
   [x]    指第x个。  比如  //div/input[2]   指div下面第二个input
   *       指任意        比如 //span[@*="xxxx"] 指定位span中任意属性等于xxx的;比如//*[@id="kw"] 指定位任意标签属性id='kw'
           用在开始表示绝对路径,从根节点选取; 用在中间表示前一个节点的下一级
   //      用在开始表示从当前节点开始;用在中间表示所有子节点,不用考虑是否直接子节点
 
常用写法:
属性定位: //标签[@属性名=属性值]
文本定位: //标签[text()=精确内容]
contains()函数定位,如果属性值或文本内容过长,可以选取其中一部分定位,  //标签[contains(@属性,属性值)]     //标签[contains(text(),部分内容)]
 
 

 
一、xpath基本定位法
  1. 使用id定位
               driver.find_element_by_xpath('//input[@id=""kw]')
 
       2.使用class定位
             driver.find_element_by_xpath('//input[@class="s_ip"]')
 
       3.当然,通过常用8种方式结合xpath均可以定位(name,tag_name,link_text,partial_link_text)
 
二、xpath相对路径/绝对路径定位
      1.相对路径定位    
            以//开头,表示从当前节点开始,如: //form//input[@name="phone"]  
 
      2.绝对路径
            以/开头,从根节点开始选取,比较繁琐,一般不建议使用   如:/html/body/div/a
 
三、xpath文本、模糊、逻辑定位
      1、文本定位 
            使用text()元素的text内容  如: //button[text()="登录"]
 
      2. 模糊定位
          使用contains()包含函数  如: //button[contains(text(),"登录")]      //button[contains(@class,"btn")]
          使用starts-with     ends-with  如://button[starts-with(@class,"btn")]    //input[ends-with(@class,"-special")]
 
    3.逻辑运算符
         and  or    如://input[@name="phone" and @datatype="m"]
 
四, xpath轴定位
       轴运算
      ancestor:祖先节点  包括父
      parent: 父节点
      preceding-sibling  : 当前元素节点标签之前的所有兄弟节点(同级)
      preceding: 当前元素节点标签之前的所有节点
      following-sbling:当前元素节点标签之后的所有兄弟节点 (同级)     如: //input/following::[1]  input的下一个兄弟元素
      following: 当前元素节点标签之后的所有节点
  
   使用方法:  轴名称::节点名称    (前后的定位与之前一致,用/隔开即可)
    使用较多的场景:页面显示为一个表格样式数据列
   

selenium---xpath定位方法详解的更多相关文章

  1. selenium+Java,xpath定位方法详解(搬运留存)

    用xpath绝对路径比较费事费力,还容易报错,下面几种模糊定位比较灵活好用 driver.findElement(By.xpath("//*[@id='J_login_form']/dl/d ...

  2. xpath定位方法详解

    1.xpath较复杂的定位方法: 现在要引用id为“J_password”的input元素,可以像下面这样写: WebElement password = driver.findElement(By. ...

  3. xpath定位中详解id 、starts-with、contains、text()和last() 的用法

    1.XPATH使用方法 使用XPATH有如下几种方法定位元素(相比CSS选择器,方法稍微多一点): a.通过绝对路径定位元素(不推荐!) WebElement ele = driver.findEle ...

  4. xpath使用方法详解id 、starts-with、contains、text()和last() 的用法

    1.XPATH使用方法 使用XPATH有如下几种方法定位元素(相比CSS选择器,方法稍微多一点): a.通过绝对路径定位元素(不推荐!) WebElement ele = driver.findEle ...

  5. C++调用JAVA方法详解

    C++调用JAVA方法详解          博客分类: 本文主要参考http://tech.ccidnet.com/art/1081/20050413/237901_1.html 上的文章. C++ ...

  6. CURL使用方法详解

    php采集神器CURL使用方法详解 作者:佚名  更新时间:2016-10-21   对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程 ...

  7. Java提高篇——equals()与hashCode()方法详解

    java.lang.Object类中有两个非常重要的方法: 1 2 public boolean equals(Object obj) public int hashCode() Object类是类继 ...

  8. PHP cURL应用实现模拟登录与采集使用方法详解

    对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程链接的数据,但是它的可控制性太差了,对于各种复杂情况的采集情景,file_get_co ...

  9. C# Process.Start()方法详解(转)

    C# Process.Start()方法详解 System.Diagnostics.Process.Start(); 能做什么呢?它主要有以下几个功能: 1.打开某个链接网址(弹窗). 2.定位打开某 ...

  10. 元素定位-XPATH定位方法总结

    1.Xpath定位方法探讨 xpath是比较常用的一种定位元素的方式,因为它很方便,缺点是,消耗系统性能.如果Xpath使用的比较好,几乎可以定位到任何页面元素,而且受页面变化影响较小. 1.1.什么 ...

随机推荐

  1. Web前端单词大全

    style 修饰width 宽度height 高度title 想说明的text-align 水平对齐方式center 居中 left 居左 right 居右line-height 垂直对齐方式/行高 ...

  2. centos7 yum安装配置Lnmp和负载配置

    首先配置防火墙CentOS 7.0默认使用的是firewall作为防火墙1.关闭firewall: systemctl stop firewalld.service #停止firewallsystem ...

  3. localStorage/sessionStorage/cookie

    html5本地存储主要有两种localStorage和sessionStorage        都是使用相同api,存入后都是字符串类型 localStorage和sessionStorage使用方 ...

  4. 洛谷P4802 [CCO 2015]路短最

    题目 https://www.luogu.com.cn/problem/P4802 思路 数据范围 \(n\leq 18\),义眼丁真,鉴定为状压. 好,那我们来思考一下状态的构建.其实是很套路的东西 ...

  5. sed: -e 表达式 #1, 字符 1: 未知的命令:“'”

    https://blog.csdn.net/linmingan/article/details/80007727 加双引号!! 利用sed更改文件test.txt的第一行为abc: sed -i '1 ...

  6. zabbix(历史数据保留时长和趋势存储时间的区别)

    zabbix(历史数据保留时长和趋势存储时间的区别)? zabbix(历史数据保留时长和趋势存储时间分别影响着哪里)? 001.影响grafana 数据展示的是历史数据还是趋势数据? 等把<历史 ...

  7. JS学习-async/await

    async/await 它保证函数的返回值为 promise. 用更少的.then()块来封装代码,同时它看起来很像同步代码 注意:可能会因为大量await的promises相继发生而变慢. asyn ...

  8. Linux环境使用Docker安装MySql

    系统环境: CentOS 7.6 64位(同样适用于Ubuntu) 安装步骤: 1.创建文件夹 /home/docker/mysql/config /home/docker/mysql/data 2. ...

  9. Web Dynpro for ABAP(16):WDA Analysis Tools

    3.21 Quality Assurance and Supportability WDA程序效能验证工具. Tests工具: eCATT and Web Dynpro ABAP Debugging工 ...

  10. 攻防世界Web篇——unserialize3

    知识点: 序列化与反序列化维基百科:    序列化(serialization)在计算机科学的数据处理中,是指将数据结构或对象状态转换成可取用格式(例如存成文件,存于缓冲,或经由网络中发送),以留待后 ...