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(' ')
效果如图