爬虫的步骤解析内容xpath介绍_爬虫入门到精通-网页的解析(xpath)
在爬虫入门到精通第五讲中,我们了解了如何用正则表达式去抓取我们想要的内容.这一章我们来学习如何更加简单的来获取我们想要的内容.
xpath的解释
XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言。
XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初XPath的提出的初衷是将其作为一个通用的、介于XPointer与XSL间的语法模型。但是XPath很快的被开发者采用来当作小型查询语言。
XPath的基本使用
要使用xpath我们需要下载lxml,在爬虫入门到精通-环境的搭建这一章也说明怎么装,如果还没有安装的话,那就去下载安装吧
直接看代码实战吧。
from lxml import etree
# 定义一个函数,给他一个html,返回xml结构
def getxpath(html):
return etree.HTML(html)
# 下面是我们实战的第一个html
sample1 = """
My pageWelcome to my page
This is the first paragraph.
"""
# 获取xml结构
s1 = getxpath(sample1)
# 获取标题(两种方法都可以)
#有同学在评论区指出我这边相对路径和绝对路径有问题,我搜索了下
#发现定义如下图
s1.xpath('//title/text()')
s1.xpath('/html/head/title/text()')
相对路径与绝对路径


总结及注意事项
获取文本内容用 text()
获取注释用 comment()
获取其它任何属性用@xx,如
@href
@src
@value
sample2 = """
- Quote 1
- Quote 2 with link
- Quote 3 with another link
Quote 4 title
...
"""
s2 = getxpath(sample2)

总结及注意事项
上面的li 可以更换为任何标签,如 p、div
位置默认以1开始的
最后一个用 li[last()] 不能用 li[-1]
这个一般在抓取网页的下一页,最后一页会用到
sample3 = """
- Scrapybegin
- Scrapinghub
- Scrapinghub Blog
- Quotes To Scrapeend
- Quotes To Scrapeend
"""
s3 = getxpath(sample3)

总结及注意事项
根据html的属性或者文本直接定位到当前标签
文本是 text()='xxx'
其它属性是@xx='xxx'
这个是我们用到最多的,如抓取知乎的xsrf(见下图)
我们只要用如下代码就可以了
`//input[@name="_xsrf"]/@value `

sample4 = u"""
My pageWelcome to my page
This is the first paragraph.
编程语言python
javascript
C#JAVA
a
b
c
d
e
f
"""
s4 = etree.HTML(sample4)

总结及注意事项
想要获取某个标签下所有的文本(包括子标签下的文本),使用string
如
123来获取我啊
,这边如果想要得到的文本为123来获取我啊",则需要使用stringstarts-with 匹配字符串前面相等
contains 匹配任何位置相等
当然其中的(@class,"content")也可以根据需要改成(text(),"content")或者其它属性(@src,"content")
最后再次总结一下
看完本篇文章后,你应该要
能学会基本所有的xpath的使用
css和这个的原理一样,所以就不介绍了,可以参考
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
