zoukankan      html  css  js  c++  java
  • Xpath的string(.)用法

    Xpath的text()与string(.)

    我们在爬取网站使用Xpath提取数据的时候,最常使用的就是Xpath的text()方法,该方法可以提取当前元素的信息,但是某些元素下包含很多嵌套元素,

    我们想一并的提取出来,这时候就用到了string(.)方法,但是该方法使用的时候跟text()不太一样,下面就举实例来讲解一下具体的区别。


    实例网站:https://www.biedoul.com/wenzi/1/  

    例如

    以这个段子为例,如果我们使用text()来拿取这个,会发现这一个段子竟然有11个text()信息,那么我们直接用text()来拿会怎么样呢?我们来看下结果

     发现我们确实拿到了,可是我们却是拿到一个列表中的多个字符串,我们想合成一个还需要拼接,所以我们可以使用 string(.),来看看效果

    发现现在就是我们想要的结果了,因此当我们需要拿取嵌套节点的内容时候,使用string(.)方法效果更好

     附上代码:

    import requests
    from lxml import etree
    url='https://www.biedoul.com/wenzi/1/'
    headers={
        'user-agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36'
    }
    response = requests.get(url,headers=headers)
    htmlweb=etree.HTML(response.text)
    #注意xpath直接拿到的是一个列表,想要使用string(.)方法要在之前的对象加上[0]
    #string(.)方法不能直接与之前的xpath写到一起,需要在之前的对象的基础上使用
    item=htmlweb.xpath("//dl[@id='xh_180839']/dd")[0].xpath("string(.)")
    print(item)

    既然写到这里了就直接附上爬取整个网站的代码吧,网站比较简单,没事用来看看段子也还凑合

    import requests
    from lxml import etree
    urllist=[]
    #构造1000页的url
    for i in range(1,1001):
        urllist.append('https://www.biedoul.com/wenzi/'+str(i)+'/')
    
    headers={
        'user-agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36'
    }
    number=0
    for url in urllist:
        print('当前网站为'+str(url))
        response=requests.get(url=url,headers=headers)
        #使用xpath时候需要先用lxml转换一下内容
        htmlweb=etree.HTML(response.content.decode())
        items=htmlweb.xpath("//dl[@class='xhlist']")
        #注意xpath拼接写法  要加上"."
        for item in items:
            print('*************************段子编号'+str(number)+'**************************************')
            print('title:'+item.xpath(".//dd/a/strong/text()")[0])
            #string(.)方法切记如何使用 可以获取节点下所有嵌套节点内容
            print('content:'+item.xpath("./dd")[0].xpath("string(.)"))
            number+=1
        print('
    ')

    效果如图

  • 相关阅读:
    ssh连接虚拟机centos
    centos安装vim
    CentOS 使用yum命令安装出现错误提示”could not retrieve mirrorlist http://mirrorlist.centos.org
    java多线程之yield,join,wait,sleep的区别
    mybatis分页插件pagehelper
    kaptcha验证码插件使用与参数
    redis主从简单配置
    从本地新建项目到提交到github
    Linux服务器安装rocketMQ单机消息队列
    Oracle通过命令导入数据存储文件
  • 原文地址:https://www.cnblogs.com/CYHISTW/p/12312570.html
Copyright © 2011-2022 走看看