Python爬虫:为什么你爬取不到网页数据

前言:

之前小编写了一篇关于爬虫为什么爬取不到数据文章(文章链接为:https://liuze.blog..net/article/details/105965562),但是当时小编也是胡乱编写的,其实里面有很多问题的,现在小编重新发布一篇关于爬虫爬取不到数据文章,希望各位读者更加了解爬虫。

1. 最基础的爬虫

通常编写爬虫代码,使用如下三行代码就可以实现一个网页的基本访问了。

from urllib import request

rsp = request.urlopen(url=某某网站)
print(rsp.read().decode(编码))

或者

import requests

rsp = requests.get(url=某某网站)
print(rsp.text)

但是,有的网站你使用上述方式访问时,有可能出现一下情况:

  1. 直接报错;
  2. 没有报错,但是给出相应的响应码,如403;
  3. 没有报错,但是输出信息没有在浏览器上看到的那么多(这有可能是网页使用了动态加载的原因)。

2. 添加请求头的爬虫

上述讲到的三种情况,怎样解决呢?基本方式是添加一个请求头(请求头的字段通常只需添加user-agent字段即可,用来模拟浏览器访问;然而有的网站用Python爬虫来访问时,可能还要添加其他字段,最好是把这个网页所有请求头字段信息全部添加上;有的网页全部请求头字段信息全部添加上,然而也访问不到数据,这种情况小编也没有什么好的解决办法,不知道使用selenium模块直接操控浏览器是否可以,没有试过)。

  1. 如用urllib模块来访问bilibili网站时会报错,如下: 但是添加请求头之后,就可以正常访问了。 参考代码如下:
  1. 如用urllib模块来访问百度网站时会出现如下情况: 很显然,这个网页不可能就这么点代码标签,添加一个请求头之后,如下:

3. 动态网页加载的数据

提到动态网页,读者首先可以去看看小编的这篇文章:,小编学习过后端知识,大体知道为什么用上述方式访问不到相应的数据。why(大概是这样吧!也有可能讲的不对,希望读者指正[如果有错误的话],一般而言,我们用爬虫爬取得到的数据是当前网页已经完全加载的,然而动态网页使用了ajax技术,而执行者一段ajax代码好像是网页完全加载之后才执行的,因此你用爬虫爬取不到那部分数据。) 此时,你有两种解决方式:

  1. 找到这个ajax的相关网页链接,访问这个链接,从而得到相关数据;
  2. 直接使用selenium这个模块,操作浏览器访问。

4. 总结

有的读者也许会问,如果我ip封掉了,怎样爬取网页数据,其实,使用相关ip代理即可,读者可以去看看小编的爬虫专栏,里面有讲ip代理的相关文章。另外,还有一些高大上的反爬措施,小编并不是很了解,就不在这一一赘述了,如果未来小编真的了解到了,到时候再在本文章后加上吧!

经验分享 程序员 微信小程序 职场和发展