Python    Xpath语法

 

一、选取节点

常用的路劲表达式:

表达式 描述 实例  
nodename 选取nodename节点的所有子节点 xpath(‘//div’) 选取了div节点的所有子节点
/ 从根节点选取 xpath(‘/div’) 从根节点上选取div节点
// 选取所有的当前节点,不考虑他们的位置 xpath(‘//div’) 选取所有的div节点
. 选取当前节点 xpath(‘./div’) 选取当前节点下的div节点
.. 选取当前节点的父节点 xpath(‘..’) 回到上一个节点
@ 选取属性 xpath(’//@calss’) 选取所有的class属性

二、谓语

谓语被嵌在方括号内,用来查找某个特定的节点或包含某个制定的值的节点

实例:

表达式 结果
xpath(‘/body/div[1]’) 选取body下的第一个div节点
xpath(‘/body/div[last()]’) 选取body下最后一个div节点
xpath(‘/body/div[last()-1]’) 选取body下倒数第二个div节点
xpath(‘/body/div[positon()<3]’) 选取body下前两个div节点
xpath(‘/body/div[@class]’) 选取body下带有class属性的div节点
xpath(‘/body/div[@class=”main”]’) 选取body下class属性为main的div节点
xpath(‘/body/div[price>35.00]’) 选取body下price元素值大于35的div节点

 三、通配符

Xpath通过通配符来选取未知的XML元素

表达式 结果
xpath(’/div/*’) 选取div下的所有子节点
xpath(‘/div[@*]’) 选取所有带属性的div节点

四、取多个路径

使用“|”运算符可以选取多个路径

表达式 结果
xpath(‘//div|//table’) 选取所有的div和table节点

五、Xpath轴

轴可以定义相对于当前节点的节点集

轴名称 表达式 描述
ancestor xpath(‘./ancestor::*’) 选取当前节点的所有先辈节点(父、祖父)
ancestor-or-self xpath(‘./ancestor-or-self::*’) 选取当前节点的所有先辈节点以及节点本身
attribute xpath(‘./attribute::*’) 选取当前节点的所有属性
child xpath(‘./child::*’) 返回当前节点的所有子节点
descendant xpath(‘./descendant::*’) 返回当前节点的所有后代节点(子节点、孙节点)
following xpath(‘./following::*’) 选取文档中当前节点结束标签后的所有节点
following-sibing xpath(‘./following-sibing::*’) 选取当前节点之后的兄弟节点
parent xpath(‘./parent::*’) 选取当前节点的父节点
preceding xpath(‘./preceding::*’) 选取文档中当前节点开始标签前的所有节点
preceding-sibling xpath(‘./preceding-sibling::*’) 选取当前节点之前的兄弟节点
self xpath(‘./self::*’) 选取当前节点

六、功能函数  

使用功能函数能够更好的进行模糊搜索

函数 用法 解释
starts-with xpath(‘//div[starts-with(@id,”ma”)]‘) 选取id值以ma开头的div节点
contains xpath(‘//div[contains(@id,”ma”)]‘) 选取id值包含ma的div节点
and xpath(‘//div[contains(@id,”ma”) and contains(@id,”in”)]‘) 选取id值包含ma和in的div节点
text() xpath(‘//div[contains(text(),”ma”)]‘) 选取节点文本包含ma的div节点
     

scrapy xpath文档:http://doc.scrapy.org/en/0.14/topics/selectors.html

最新文章

  1. DPM算法源程序voc-release5在Windows中的配置修改过程
  2. P1220 关路灯
  3. 第二天 ado.net, asp.net ,三层笔记
  4. 锋利的JQuery 学习笔记
  5. Mysql 删除语句
  6. Android学习笔记----TimerTask中显示Toast的问题
  7. 【JavaScript回顾】继承
  8. 新浪微博客户端(13)-使用UIWebView加载OAuth授权界面
  9. iframe session过期跳转到登陆页面
  10. 板级支持包(BSP)
  11. 在Android Studio中进行单元测试和UI测试
  12. DLL 导出变量
  13. 非极大值抑制(Non-Maximum Suppression,NMS)
  14. JS快速入门笔记
  15. 分析Linux上的程序依赖
  16. C# SQLite数据库操作
  17. 阿里开源项目之Ant Design Pro
  18. IIS-设置session时间
  19. Xshell配置ssh免密码登录-密钥公钥(Public key)
  20. solr特点九:word(分词)

热门文章

  1. CloudIDE:为开发者写代码开启“加速”模式
  2. 软件篇-02-基于ZED 2和ORB_SLAM2的SLAM实践
  3. Sublime Text 3 Build 3176 License
  4. 什么是响应式web设计
  5. hdu3234 带权并查集(XOR)
  6. 在Android so文件的.init、.init_array上和JNI_OnLoad处下断点
  7. Windows核心编程 第26章 窗口消 息
  8. 学javaweb 先学Servlet 应用理论很重要
  9. phpstorm 实现分屏显示
  10. 想要测试Dubbo接口?测试的关键点在哪里?