Xpath使用方法

Posted 尘世风

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Xpath使用方法相关的知识,希望对你有一定的参考价值。

由于最新版火狐不在支持FireBug等开发工具,可以通过https://ftp.mozilla.org/pub/firefox/releases/ 下载49版本以下的火狐就可以增加Firebug等扩展了。

什么是Xpath?

XPath是XML的路径语言,通俗一点讲就是通过元素的路径来查找到这个标签元素。

工具

Xpath的练习建议大家安装火狐浏览器后,下载插件,FireBug。

Xpath使用方法

注:默认死格式 先写 //* 代表定位页面下所有元素

1、Xpath支持ID、Class、Name定位功能

  1)、通过ID定位
 
    //*[@id=‘kw‘]
 
  2)、通过Class定位
 
    //*[@class=‘class_name‘]
 
  3)、通过Name定位
 
    //*[@name=‘name‘]

2、如果标签没有ID、Class、Name三总属性,Xpath还支持属性定位功能

3、当标签的属性重复时,Xpath提供了通过标签来进行过滤

      将 * 换位任意标签名,则可根据标签进行筛选
      //input[@placeholder=‘用户名‘]

4、当标签页重复时,Xpath提供了层级过滤

例如:找不到儿子,那么就先找他的爸爸,是在不行可以在找他的爷爷

5、一个元素它的兄弟元素跟它的标签一样,这时候无法通过层级定位到。因为都是一个父亲生的,多胞胎兄弟。Xpath提供了索引过滤

    通过索引,在List中定位属性,与python的索引有些差别,Xpath从1开始
      //select[@name=‘city‘][1]/option[1]

6、上面集中如果都用上了之后还重复的话,我们就可以使用Xpath提供的终极神器,逻辑运算定位。and 或 or   

    1)、通过and来缩小过滤的范围,只有条件都符合时才能定位到
 
      //select[@name=‘city‘ and @size=‘4‘ and @multiple="multiple"]
 
    2)、or就相反了,只要这些筛选中,其中一个出现那么久匹配到了
 
      //select[@name=‘city‘ or @size=‘4‘]

我通常把Xpath看成是屠龙刀。武林至尊,宝刀Xpath,Css不出,谁与争锋?

以上是关于Xpath使用方法的主要内容,如果未能解决你的问题,请参考以下文章

Xpath的使用

XML编程总结——使用XPath对象查询xml文档

Xpath使用方法

selenium- Xpath的详细使用

Python爬虫 解析 xpath -- Xpath Helper插件的安装xpath的基本使用

xPath技术