前言
xpath解析原理:
1.实例化一个etree的对象,且需要将被解析的页面源码数据加载到该对象中。
2.调用et ree对象中的xpath方法结合着xpath表达式实现标签的定位和内容的捕获。
环境的安装:
如何实例化一个etree对象:
1.将本地的html文档中的源码数据加载到etree对象中:
2.可以将从互联网上获取的源码数据加裁到该对象中
1
|
etree.HTML( 'page_ text' )
|
1
2
3
4
5
6
7
8
9
10
|
#3.7版本后引入etree模块如下,3.5版本以下可以直接从lxml中引入
from lxml import html
etree = html.etree
parser = etree.HTMLParser(encoding="utf-8")
#实例化好了一个etree对象,且将被解析的源码加载到了该对象中
tree = etree.parse('bs4练习.html', parser=parser)
# r = tree.xpath('/html/body/div')
# r = tree.xpath('/html//div')
# r = tree.xpath('//div')
|
/表示的是从根节点开始定位,一个/x/表示一个层级,//表示跨越多个层级,可以表示从任意位置开始定位
1
|
r = tree.xpath('//div[@class="song"]')
|
属性定位:
1
|
//div[@class="song"] tag[@attrName="attrValue"]
|
1
|
r = tree.xpath('//div[@class="song"]/p[3]')
|
索引定位:
1
|
'//div[@class="song"]/p[3]' #这里索引以1开始
|
1
2
3
|
r = tree.xpath('//div[@class="tang"]//li[5]/a/text()')[0]
取文本:
|
/text() #获取的是标签中直系的文本内容
//text() #获取标签中非直系文本内容(所有文本内容)
1
2
3
|
```python
r = tree.xpath('//div[@class="tang"]/text()')
|
取属性:
/@attrName ==>img/src
1
|
r = tree.xpath('//div[@class="song"]/img/@src')
|
实际案例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
#3.7版本后引入etree模块如下,3.5版本以下可以直接从lxml中引入
from lxml import html
import requests
etree = html.etree
a = True
while a:
#爬取页面源码数据
url = 'https://mm.58.com/ershoufang/'
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36'
}
page_text = requests.get(url=url, headers=headers).text
#数据解析
tree = etree.HTML(page_text)
li_list = tree.xpath('//ul[@class="house-list-wrap"]/li')
fp = open('58.txt', 'w', encoding='utf-8')
for li in li_list:
#页面数据局部解析
title = li.xpath('./div[2]/h2/a/text()')[0]#./表示从前面的li开始(局部开始)
print(title)
fp.write(title+'\n')
a = False
|