爬虫笔记(四)——代理服务器的设置

        使用同一个IP去爬取同一个网站上的网页,久了之后会被该网站服务器屏蔽。这个时候我们就可以使用代理服务器。 (使用代理服务器去爬取某个网站的内容的时候,在对方的网站上,显示的不是我们真实的IP地址,而是代理服务器的IP地址)。给大家推荐一个网址:http://www.xicidaili.com/,这上面有免费的代理Ip。我们尽量找验证时间比较短的,这样的成功率会比较大。

我们可以看到图片的第一个ip地址,101.236.60.48,对应的端口号为8866,则完整的格式为:“ip地址:端口号",即101.236.60.48:8866。选择好代理ip地址后,我们就可以进行相应的程序编写了,可以使用以下程序,实现通过代理服务器来爬取网站内容。

import urllib.request
import urllib.parse

url = "https://mp.csdn.net/postlist/list/enable"
proxy = urllib.request.ProxyHandler ({'http':'101.236.60.48:8866'})
opener = urllib.request.build_opener(proxy)
opener.addheaders = [('User-Agent','Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:45.0) Gecko/20100101 Firefox/45')]
urllib.request.install_opener(opener)
data = urllib.request.urlopen(url).read()
print (len(data))
fhandle = open('/home/wl/csdn.html','wb')
fhandle.write(data)
fhandle.close()
  • urllib.request.ProxyHandler(proxy)函数是用来设置对应的代理服务信息,代理信息的格式为:{'http':代理服务器地址}。
  • urllib.request.build_opener()函数创建一个opener对象。
  • urllib.request.install_opener()将opener变成全局默认的对象。

 

转载于:https://www.cnblogs.com/longwhite/p/10397766.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值