Python 爬虫学习笔记(二)

Python 爬虫学习笔记(二)分析网页我们平时使用浏览器来访问网页,实质上来看,就是通过一个客户端经过网络连接访问了服务器端,访问前,我们的页面没有任何内容,那么这些内容必然都是从服务器端传输过来的。爬虫的工作就是利用编程的方式自动化地从服务器端获取并分析数据,得到我们需要爬取的内容。因此想要利用爬虫获取内容,首先需要我们分析目标网站页面,了解其数据排列方式,知晓其数据传输过程,从而能够制订正确有效的爬取途径。以CSDN中我本人之前的一篇文章为例https://blog.csdn.net/qq_26292987/article/

大家好,又见面了,我是你们的朋友全栈君。

分析网页

我们平时使用浏览器来访问网页,实质上来看,就是通过一个客户端经过网络连接访问了服务器端,访问前,我们的页面没有任何内容,那么这些内容必然都是从服务器端传输过来的。爬虫的工作就是利用编程的方式自动化地从服务器端获取并分析数据,得到我们需要爬取的内容。

因此想要利用爬虫获取内容,首先需要我们分析目标网站页面,了解其数据排列方式,知晓其数据传输过程,从而能够制订正确有效的爬取途径。

以CSDN中我本人之前的一篇文章为例
https://blog.csdn.net/qq_26292987/article/details/107608315

如果我们希望获取这个页面上的文章内容而不希望自己动手去复制粘贴,爬虫是一个非常有效的工具,而分析这个页面有几个方向:

(一)分析页面源代码:
在页面上单击右键,可以看到选项“查看页面源代码”(这里我使用的是Microsoft Edge浏览器,不同浏览器可能有所不同),弹出的新网页内容如图:
页面源代码图片
如何能够在繁杂的代码信息中快速找到我们需要的内容呢?
【1】查找大法好
“Ctrl+F”,搜索要查找的关键词,看是否能得到结果,这里目的是查找文章内容,直接搜索“BeautifulSoap用法”即可得到如下界面
查找结果
那么为什么选择搜索“BeautifulSoap用法”而不是题目或者其他呢?简单查看源代码即可发现,题目在源代码中多次出现,不能很好的确定文章位置,第一段同理(第一段主要是本人编辑的问题)
【2】进阶方法
对于这个方法,首先需要对网页源代码的组织方式有一定的了解,也就是需要对HTML相关知识有亿点点了解:https://www.runoob.com/html/html-tutorial.html
经过简单的学习(After ten thousands years)
我们知道了:
HTML是一种标记语言,有严谨的标签设置来确定其中每一部分的功能,而更关键的是:

HTML 标签是由尖括号包围的关键词,比如 <html>
HTML 标签通常是成对出现的,比如 <b></b>
标签对中的第一个标签是开始标签,第二个标签是结束标签
开始和结束标签也被称为开放标签和闭合标签

声明为 HTML5 文档

<html> 元素是 HTML 页面的根元素
<head> 元素包含了文档的元(meta)数据,如 <meta` charset=“utf-8”> 定义网页编码格式为 utf-8。

<title> 元素描述了文档的标题
<body>> 元素包含了可见的页面内容
<h1> 元素定义一个大标题
<p> 元素定义一个段落
<a> 元素定义一个链接
<img> 元素定义一个图像
<div><span> 元素定义一个区块
<script>定义一个脚本(运行的函数)

有了上面这些知识,那我们需要的东西一定是在body里去找的,具体在哪里找呢?(实话说还是“Ctrl+F”更方便,这些知识更多的是为了下一步从页面中获取内容所需要的)这里我个人推荐sublime作为暂时的阅览器,配置好该软件的“HTML/CSS/JS Prettify”模块之后,只需要轻轻一点,那些没有缩进和对齐的代码就变成了下面这样:
在这里插入图片描述
随后就可以比较方便的通过折叠查找等方式获得我们需要的内容了

(二)分析页面元素
在页面上按“F12”,神奇的事情出现了,页面的右侧(有的浏览器是下方)发生了有趣的变化:
在这里插入图片描述
其上方菜单栏有“元素、控制台、源代码、网络、性能、内存”等几个选项,现在我们只需要注意“元素、网络”两个部分就够了!
元素区系统的展示了页面上全部的元素和内容及其排布方式,修改其中的内容,页面上的内容也会发生相应的改变(别担心,服务器端存储的内容没有改变),将鼠标移到相应的位置,可以看到左侧相应的内容出现了被选中的效果,现在再去寻找元素所在的位置就轻松多了吧。

(三)分析网络传输
如果你对前面的内容还有印象,那你应该还记得,页面上的所有内容都是服务器端传输到我们的浏览器上的,也就是说,页面上的每一个元素都是服务器端传输的结果,在网络中可以看到这个过程:
在这里插入图片描述
看到这么一堆乱七八糟的东西,我的内心是崩溃的(这都啥玩意儿啊)
没事儿,无所不能的网络告诉我们,遇到事情不要慌,先拿出手机拍一张(笑)
首先我们可以看类型,从图片中可以清晰的看到其传输的很大一部分内容都是png、gif之类的图片,那么这些图片是什么呢?一般我们可以点击左侧的名称,在弹出的预览页面中看到他们主要是一些页面上的图标、广告等需要图片的元素;其次是script,这个我们已经了解了,它是一种网页上使用的脚本函数,那这些“.js”文件大概率就是网页上运行的脚本函数的内容;紧接着是text,从类型上可以看出来,这是一种文本文件,与其相似的还有类型为document的文件流,这些文件中的内容很多是和我们需要的内容直接相关的。
其次我们可以分析文件名称,确实,文件名称也是乱糟糟的,但是,如果这些文件名称真的是乱糟糟的没有规律,那网站的运维人员又该如何在一团乱麻中快准狠找到问题解决问题呢?所以坚信一点,只要是人设计的,就一定是有规律可循的,就一定是有漏洞的,然后通过多个网页的对比,总能够找到我们需要的东西。
再次,我们可以去看大小。很多时候,要分析的页面所包含的最重要的信息其文件传输流一定不会很小,因此一些只有几个B的信息流在分析的时候可以忽略掉,按照信息流的大小来判断其重要与否是一个很方便且有必要的方式。

那么,对于初级的爬虫学习者来说,用好这三个方法,很多网页就可以去尝试着分析并寻找其有价值的信息藏在何处从而将其爬取到自己的电脑上了。然而,如果说爬虫是网络世界爬取信息最锋利的矛,那么为了保护自己的网站信息不被随意爬取(毕竟信息就是金钱),同时也为了让网站的设计和使用更加便利,网站使用了很多方式来优化自己,有意无意间给我们的爬取带来了很多困难,常见的如异步信息流、动态页面加载、登陆验证、ip访问次数限制等等,其中的一些可以通过分析网页解决,大部分都需要我们针对不同的网站对自己的程序做不同的优化处理才能够解决。那么,接下来我们先做一个小项目,初步尝试一下爬虫获取数据的快乐吧!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/125155.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 2022 pycharm 激活码【2022最新】2022.03.10

    (2022 pycharm 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~1…

    2022年4月2日
    201
  • MySQL常用命令大全(完整)

    MySQL常用命令大全(完整)打开Linux或MacOS的Terminal(终端)直接在终端中输入windows快捷键win+R,输入cmd,直接在cmd上输入1、mysql服务的启动和停止netstopmysqlnetstartmysql启动失败可按快捷键win+R,输入services.msc,找到MySQL服务器的名称启动2、登陆mysqlmysql(…

    2022年6月30日
    24
  • Github提交代码却没有显示绿色小格子?帮你找回绿格子!

    Github提交代码却没有显示绿色小格子?帮你找回绿格子!辛辛苦苦提交的代码却没有绿格子?在github上提交代码之后,进入github上面查看自己的提交,可以看看刚刚的提交内容,但是却一直没有显示绿格子,一个原因是本地git的配置邮箱和github上面的邮箱不一致。解决方法:查看你的本地配置邮箱在命令行中输入:gitconfiguser.email查看你的本地配置邮箱.看看是否和github上面绑定的邮箱一致,如果不一致则更改一下。…

    2022年9月28日
    0
  • 深度剖析LinkedHashSet「建议收藏」

    深度剖析LinkedHashSet「建议收藏」HashMap是一个利用数组存储key-value键值对的一个数据结构,为了有序的要求,然后我们引入了LinkedHashMap来满足我们对顺序的要求,再到后面我们学习了HashSet这种数据结构,利用的是HashMap的Key的唯一性来实现HashSet的去重的目的LinkedHashSet也HashSet一样也在内部使用了HashMap,因为LinkedHashSet要维持元素之间的顺序,所以它使用的实HashMap的有序版本,也就是LinkedHashMap

    2022年10月12日
    0
  • C++ vector初始化_vector初始化大小

    C++ vector初始化_vector初始化大小一维向量vector<int>vector_1D_1;//只定义向量vector<int>vector_1D_2(n);//定义的同时初始化大小vector<int>vector_1D_3(n,m);//定义的同时初始化大小为n,元素初始值为m//先定义变量,再初始化大小和初值vector<int>vector_1D_4;vector_1D_4=vector<int>(n,m);二维向量vector<vector&

    2022年9月18日
    0
  • linux nmap命令,nmap命令

    linux nmap命令,nmap命令nmap(“NetworkMapper(网络映射器)”)是一款开放源代码的网络探测和安全审核的工具。它的设计目标是快速地扫描大型网络,当然用它扫描单个主机也没有问题。Nmap以新颖的方式使用原始IP报文来发现网络上有哪些主机,那些主机提供什么服务(应用程序名和版本),那些服务运行在什么操作系统(包括版本信息),它们使用什么类型的报文过滤器/防火墙,以及一堆其它功能。虽然Nmap通常用于…

    2022年5月28日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号