809669515

2018-10-19   阅读量: 912

数据分析师 Python数据分析 Python爬虫 Python编程

python网络爬虫 - 如何伪装逃过反爬虫程序

扫码加入数据分析学习群

有的时候,我们本来写得好好的爬虫代码,之前还运行得Ok, 一下子突然报错了。

报错信息如下:

Http 800 Internal internet error

这是因为你的对象网站设置了反爬虫程序,如果用现有的爬虫代码,会被拒绝。

之前正常的爬虫代码如下:

from urllib.request import urlopen

...

html = urlopen(scrapeUrl)

bsObj = BeautifulSoup(html.read(), "html.parser")

这个时候,需要我们给我们的爬虫代码做下伪装,

给它添加表头伪装成是来自浏览器的请求

修改后的代码如下:

import urllib.parse
import urllib.request
from
bs4 import BeautifulSoup
...
req
= urllib.request.Request(scrapeUrl)
req.add_header(
'User-Agent'
, 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)')
response
= urllib.request.urlopen(req)
html
= response.read()

bsObj
= BeautifulSoup(html, "html.parser")

Ok,一切搞定,又可以继续爬了。

添加CDA认证专家【维克多阿涛】,微信号:【cdashijiazhuang】,提供数据分析指导及CDA考试秘籍。已助千人通过CDA数字化人才认证。欢迎交流,共同成长!
0.0000 0 3 关注作者 收藏

评论(0)


暂无数据

推荐课程

推荐帖子