zoukankan      html  css  js  c++  java
  • selenium xpath定位方式整理

    #xpath定位元素方法:
    /html/body/div[2] #绝对路径定位
    #相对路径定位元素
    //* #找到所有的元素
    //input #找到input元素
    //*[@*] #表示有属性的所有元素
    //*[@id] #找到所有包含id属性的元素
    //*[@id="div1"] #找到id为div1的元素
    //*[@id="div2" and @name="wulaoshidiv"] #找到同时具备两个属性的元素(必杀技)
    //*[@id="div1" or @name="wulaoshidiv"] #找到其中一个具备属性的元素
    //*[@id!="div1"] #找到id不等于div1的元素
    //*[contains(@name,"wulao")] #找到部分属性值的元素
    //*[.="挺风和日丽的"] #通过文本定位页面元素(找到两个元素)
    //div[@id="div1"]/*[.="挺风和日丽的"] #先找到div1的元素,然后定位文本元素
    //div[@id="div1"]/*[contains(.,"风和")] #模糊查找元素
    //div[@id='div1']/p[3] #找到div元素下的第3个p元素
    //div[@id='div1']/p[last()] #找到div元素下最后一个p元素
    //div[@id='div1']/p[last()]/.. #找到上一级元素
    //div[@id='div1']/* #找到div1下所有的子节点
    //p[.>20] #找到元素p中值大于20的元素
    //p[text()=20] #找到p元素中文本为20的元素(.和text()相同)
    
    
    #亲属关系匹配(轴)
    parent::* #表示当前节点的父节点元素
    ancestor::* #表示当前节点的祖先节点元素(所有的)
    child::* #表示当前节点的子元素
    /A/descendant::* #表示A的所有后代元素
    self::* #表示当前节点的自身元素
    ancestor-or-self::* #表示当前节点的及它们的后代元素
    following-sibling::* #表示当前节点的后面所有兄弟节点元素
    preceding-sibling::* #表示当前节点的前面所有兄弟节点元素
    following::* #表示当前节点的后序所有元素
    preceding::* #表示当前节点的所有元素

    #练习:
    
    
    //p[.=50]/preceding-sibling::p[1] #找到p元素值为50的上一个p元素
    
    
    //p[.=40]/following-sibling::p[1] #找到p元素值为50的下一个兄弟p元素
    
    
    //p[.=40]/parent::div #找到当前节点父元素
    
    
    //p[.=40]/ancestor::div/preceding-sibling::div #找到p为40的父元素的上一个div兄弟元素
    
    
    //*[@id='div1']/child::p[1] #找到id属性值为div1的下一级p的第一个元素
     
  • 相关阅读:
    第九届蓝桥杯JavaA组省赛真题
    Qt的IDE开发环境(KDevelop,MonKey Studio,QDevlop,Dev-cpp,Cobras,Edyuk)
    Eclipse+Qt开发环境设置(Linux和Win)
    Visual Studio 2005安装qt-win-commercial-src-4.3.1,并设置环境变量
    在VC6.0中编译头文件时产生moc文件
    Qt配置信息设置(QSettings在不同平台下的使用路径)
    应对业务需求变化?
    开发环境准备:Ruby on Rails开发环境配置
    VS2013中Python学习环境搭建
    JQUERY 插件开发——MENU(导航菜单)
  • 原文地址:https://www.cnblogs.com/xiaoxiao075/p/10689631.html
Copyright © 2011-2022 走看看