• 06 xpath选择器


    xpath

    xpath: XPath 是一门在 XML 文档中查找信息的语言

    三个关键:

    /   从根节点选取。
    // 不管位置,直接找
    /@属性名
    

    文本内容:

    doc='''
    <html>
     <head>
      <base href='http://example.com/' />
      <title>Example website</title>
     </head>
     <body>
      <div id='images'>
       <a href='image1.html' aa='bb'>Name: My image 1 <br /><img src='image1_thumb.jpg' /></a>
       <a href='image2.html'>Name: My image 2 <br /><img src='image2_thumb.jpg' /></a>
       <a href='image3.html'>Name: My image 3 <br /><img src='image3_thumb.jpg' /></a>
       <a href='image4.html'>Name: My image 4 <br /><img src='image4_thumb.jpg' /></a>
       <a href='image5.html' class='li li-item' name='items'>Name: My image 5 <br /><img src='image5_thumb.jpg' /></a>
       <a href='image6.html' name='items'><span><h5>test</h5></span>Name: My image 6 <br /><img src='image6_thumb.jpg' /></a>
      </div>
     </body>
    </html>
    '''
    

    一、使用方法

    1 所有节点

    a=html.xpath('//*')
    

    2 指定节点(结果为列表)

    a=html.xpath('//head')
    

    3 子节点,子孙节点

    a=html.xpath('//div/a')
    a=html.xpath('//body/a') #无数据
    a=html.xpath('//body//a')
    

    4 父节点

    a=html.xpath('//body//a[@href="image1.html"]/..')
    a=html.xpath('//body//a[1]/..')
    # 也可以这样
    a=html.xpath('//body//a[1]/parent::*')
    

    5 属性匹配

    a=html.xpath('//body//a[@href="image1.html"]')
    

    6 文本获取(常用)

    a=html.xpath('//body//a[@href="image1.html"]/text()')
    a=html.xpath('//body//a/text()')
    

    7 属性获取 @href 取当前标签的属性

    a=html.xpath('//body//a/@href')
    
    

    注意从1 开始取(不是从0)

    8 属性多值匹配

    # a 标签有多个class类,直接匹配就不可以了,需要用contains
    a=html.xpath('//body//a[@class="li"]')
    a=html.xpath('//body//a[contains(@class,"li")]')
    a=html.xpath('//body//a[contains(@class,"li")]/text()')
    
    

    9 多属性匹配

    a=html.xpath('//body//a[contains(@class,"li") or @name="items"]')
    a=html.xpath('//body//a[contains(@class,"li") and @name="items"]/text()')
    a=html.xpath('//body//a[contains(@class,"li")]/text()')
    
    

    10 按序选择

    a=html.xpath('//a[2]/text()')
    a=html.xpath('//a[2]/@href')
    # 取最后一个
    a=html.xpath('//a[last()]/@href')
    # 位置小于3的
    a=html.xpath('//a[position()<3]/@href')
    # 倒数第二个
    a=html.xpath('//a[last()-2]/@href')
    
    

    11 节点轴选择

    # ancestor:祖先节点
    # 使用了* 获取所有祖先节点
    a=html.xpath('//a/ancestor::*')
    # # 获取祖先节点中的div
    a=html.xpath('//a/ancestor::div')
    # attribute:属性值
    a=html.xpath('//a[1]/attribute::*')
    a=html.xpath('//a[1]/@aa')
    # child:直接子节点
    a=html.xpath('//a[1]/child::*')
    a=html.xpath('//a[1]/child::img/@src')
    # descendant:所有子孙节点
    a=html.xpath('//a[6]/descendant::*')
    a=html.xpath('//a[6]/descendant::h5/text()')
    # following:当前节点之后所有节点(兄弟节点和兄弟内部的节点)
    a=html.xpath('//a[1]/following::*')
    a=html.xpath('//a[1]/following::*[1]/@href')
    # following-sibling:当前节点之后同级节点(只找兄弟)
    a=html.xpath('//a[1]/following-sibling::*')
    a=html.xpath('//a[1]/following-sibling::a')
    a=html.xpath('//a[1]/following-sibling::*[2]')
    a=html.xpath('//a[1]/following-sibling::*[2]/@href')
    
    
  • 相关阅读:
    Python3.4的Pillow库实现验证码图片
    希尔排序
    二分法排序
    [算法天天练]选择排序
    冒泡 [Python]
    python -- 结构数据类型(列表、元组、集合、字典)
    python -- 字符串操作
    python -- 基础语法
    python -- 环境搭建
    Unittest方法 -- 以test开头实例
  • 原文地址:https://www.cnblogs.com/bailongcaptain/p/13440618.html
Copyright © 2020-2023  润新知