网站首页 > 技术文章 正文
python中使用xpath的场景
? 我们一般是在爬虫中会用到xpath对网页源代码进行信息的筛选与提取,具体而言,主要筛选的信息有以下几种:
? 1,某个标签中文本的获取
? ? eg:<title>my love</title> 中my love的获取
? 2,某个标签中属性的获取
? ? eg:<title class=“beautiful”>my love</title> 中class属性的获取
html文档结构的分析
?整个网页其实可以看作是一个大方块套着各式各样的小方块,每个方块中可以嵌入文字,图片等东西。
以bing搜索网页为例,如下图:
最大的一个网页的方块,
其中又有搜索框方块、页眉方块、
而搜索框方块中又包含了一个搜索图标的方块。
在html(超文本标记语言)中,这些方块就用标签来表示,
而方块的包含关系,也就形成了标签的包含关系(父子关系),并列关系(兄弟关系)。
每个方块又要指定固定的自己的样式,于是就有各种属性被包含在标签中。
<!DOCTYPE HTML>
<html>
<body> #两个尖括号括起来为一个标签 如 <body></body>
<title>
a book
</title>
<ol>
The truth about elk.
</ol>
<ol>
<li class="a">An elk is a smart #标签中的额外东西为属性 如 class="a"
<span>starfish</span>
</li>
<li>...and cunning animal!</li>
</ol>
</body>
</html>
如以上html文档可以转换成以下dom树
代码操作
利用lxml可以将标签关系变成一个树的形式,来体现标签的关系以便查找
所以先导入模块:
from lxml import html
将网页源代码解析成树的dom树的形式:
tree=html.fromstring(r_text) #r_text为requests请求后的网页源代码
之后我们便是对dom树利用xpath语法进行我们所需要搜索的节点
tree.xpath('xpath') #xpath为所写的xpath路径
xpath最常用的讲解
?最开始的目的中讲了我们的目的是获得一个节点中的文本或者是属性,所以我们的问题有两个:
- 如何定位我们所要找的节点
- 找到节点后如何获取属性和文本
- 如何定位我们所要找的节点
//li #选取所有的li节点
# ‘//’为选取所有的操作符
//li[0] #选取所有的li节点中的第一个节点
//li[@class="a"] #选取所有带有属性class=“a”的li节点
//li[@class="a"] /span #选取所有带有属性class=“a”的li节点下的span节点
- 找到节点后如何获取属性和文本
//li[0]/@class
#选取所有的li节点中的第一个节点并获得其class属性的值
#‘/@’为获取其属性操作符
//li[@class="a"] /span/text()
#选取所有带有属性class=“a”的li节点下的span节点,并获取其中的文本
# ‘/text()’为获取文本的操作符
骚操作大法
?但其实我们在实际操中使用的最广泛的方法为
- 点击f12查看网页源代码
- 点击该箭头(元素选择器)
- 在网页中找到我们所需要搜索的元素并点击
此时源代码展示处会自动定位到我们所选的标签处 - copy其xpath并 进行适当修正后进行操作
(不稍稍修正可能达不到你的目的呦)
(但其实有时候特征很明显的时候自己写反而会更简单)
实战 爬取豆瓣电影top250第一页电影的引言
代码如下很easy:
import requests
from lxml import html
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.104 Safari/537.36'}
url = 'https://movie.douban.com/top250'
r = requests.get(url, headers=headers)
tree = html.fromstring(r.text)
# copy的xpath
# quotes_a=[]
# quotes_a.append(tree.xpath('//*[@id="content"]/div/div[1]/ol//li/div/div[2]/div[2]/p[2]/span/text()'))
# print(quotes_a)
# 自己写的xpath
quotes_b = [] #创建引言的列表
quotes_b.append(tree.xpath('//span[@class="inq"]/text()'))
print(quotes_b)
更深入的学习
xpath教程:https://www.w3school.com.cn/xpath/index.asp
html教程:https://www.w3school.com.cn/html/index.asp
此文章为本人的学习笔记,大家有问题欢迎评论和私信,共同学习进步。
猜你喜欢
- 2024-11-14 Playwright自动化测试工具之元素定位实战
- 2024-11-14 利器 | AppCrawler 自动遍历测试实践(二):定制化配置
- 2024-11-14 java组件HuTool相关工具类的使用二
- 2024-11-14 手把手教你爬取热门小说《诡秘之主》
- 2024-11-14 Python爬虫之xpath用法全解析(py xpath)
- 2024-11-14 怎么用xpath写drissionpage?或者用相对位置?
- 2024-11-14 通过python+Xpath实现抓取某网站推荐的歌曲
- 2024-11-14 Python自动化工具(python写自动化工具)
- 2024-11-14 web自动化测试——xpath常用案例(web自动化测试平台)
- 2024-11-14 手把手教你如何用Python爬取网站文本信息
- 最近发表
-
- count(*)、count1(1)、count(主键)、count(字段) 哪个更快?
- 深入探索 Spring Boot3 中 MyBatis 的 association 标签用法
- js异步操作 Promise fetch API 带来的网络请求变革—仙盟创梦IDE
- HTTP状态码超详细说明_http 状态码有哪些
- 聊聊跨域的原理与解决方法_跨域解决方案及原理
- 告别懵圈!产品新人的接口文档轻松入门指南
- 在Javaweb中实现发送简单邮件_java web发布
- 优化必备基础:Oracle中常见的三种表连接方式
- Oracle常用工具使用 - AWR_oracle工具有哪些
- 搭载USB 3.1接口:msi 微星 发布 990FXA Gaming 游戏主板
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)