QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4204|回复: 0
打印 上一主题 下一主题

Python爬虫常用小技巧之设置代理IP

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2021-1-8 17:22 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    . P5 |% q/ d# m4 Q8 l
    Python爬虫常用小技巧之设置代理IP

    + g) F+ m# k' h, z8 m! ^+ p( V' M5 W7 E. j
    设置代理IP的原因
    4 w! j1 j( s- q# p& H1 m( Z我们在使用Python爬虫爬取一个网站时,通常会频繁访问该网站。假如一个网站它会检测某一段时间某个IP的访问次数,如果访问次数过多,它会禁止你的访问。所以你可以设置一些代理服务器来帮助你做工作,每隔一段时间换一个代理,这样便不会出现因为频繁访问而导致禁止访问的现象。
    ! C. D" S$ e; f& ]/ \( D我们在学习Python爬虫的时候,也经常会遇见所要爬取的网站采取了反爬取技术导致爬取失败。高强度、高效率地爬取网页信息常常会给网站服务器带来巨大压力,所以同一个IP反复爬取同一个网页,就很可能被封,所以下面这篇文章讲述一个爬虫技巧,设置代理IP
    , J  b, H1 Q2 l9 g6 @' P代理的获取有很多方式,网上有很多免费的可以去爬取一些试试,但是免费的代理使用起来也是 很吃力的。还有就是现在网上有很多的代理供应商,可以在网上寻找下,然后找家靠谱的使用。毕竟网络太大了,代理供应商肯定也是参差不齐的,所以找到合适的代理还是需要花点时间的。在这里我就是使用了我们长期使用的一家质量好的代理,亿牛云代理,而且是使用的他们的爬虫代理(动态转发)和一般的api模式不一样。这种更简单更方便,对于懒人来说绝对是最佳选择。& p- c% V" H( ~8 v' I: [4 F
    具体代码的使用" W3 ]9 E" L5 Q, |, S
    #! -*- encoding:utf-8 -*-
    1 A& Z( y9 R" K* _9 ?3 d  y' `/ s. m* P, K
            import requests
    1 T, \/ W6 Q, z! m$ {! _* q3 D0 j        import random7 Y7 [+ p% F  J( Q- J$ \% Z; M
    ; A5 ^+ B( \: P* M
            # 要访问的目标页面
    ( P: K( @* f, I5 o        targetUrl = "http://httpbin.org/ip", B8 S# f# p8 U/ t9 ^  m

    % b8 h- B4 k& X5 f, S( @+ [        # 要访问的目标HTTPS页面
    ' U5 z! S: {0 m1 y2 l9 l8 {" r        # targetUrl = "https://httpbin.org/ip"
    " a- l+ }! ~; y% u0 f2 O! p
    " s3 P+ f  T. g        # 代理服务器) Z6 D/ @* Q: F7 L, T4 H
            proxyHost = "t.16yun.cn"5 C% U) O! ?, n; s# e, v
            proxyPort = "31111"
    ) E1 L8 s  n$ _; Y3 b/ S
    3 L  L0 q$ x4 D" o& W% ]        # 代理隧道验证信息$ K% |" P6 P! y. l" j; _
            proxyUser = "username"
    2 d* s  |' B0 C# \! C$ u5 @$ n        proxyPass = "password") _8 w; r+ x: T" G
    5 u, \; n* d6 G
            proxyMeta = "http://%(user)s:%(pass)s@%(host)s:%(port)s" % {
    5 Y2 I$ f; Z6 U( Q7 n            "host" : proxyHost,
    ; k4 j4 e% L) g! x            "port" : proxyPort,2 t1 L  _" _' v0 X! _. R
                "user" : proxyUser,; o- V  g2 x7 {
                "pass" : proxyPass,
    6 ?6 V  Z4 U# {1 C# P" ^1 w        }
    0 {, @7 X" Q0 }9 P8 z) Q7 G, y% }; N( R4 M& J4 x
            # 设置 http和https访问都是用HTTP代理1 [) M/ p3 W; H3 E
            proxies = {
    . n0 g( T+ L" R4 N' e            "http"  : proxyMeta,
    0 m" h  @3 W3 U3 W0 d/ G0 B; H            "https" : proxyMeta,
    1 a' Y) W4 ~6 w, j4 q9 ^        }
    * p& X) h8 l) \1 J6 G
    ! S. |: X' D: \+ {! g" W5 g
    4 u- T! ^1 v$ d2 n$ x        #  设置IP切换头
    : j7 b! H. C5 I4 Q% _        tunnel = random.randint(1,10000)
    8 Q8 O  c1 s( ]& l9 x6 z% n' {        headers = {"Proxy-Tunnel": str(tunnel)}
    ( o9 u0 N$ G0 P) P; \8 ^        resp = requests.get(targetUrl, proxies=proxies, headers=headers)8 u# O8 z8 Y9 j( K3 g) e- A

    0 _9 G) T9 m: |4 F        print resp.status_code, Q  C! H7 ^' q  j- m
            print resp.text" f6 P; @9 I0 S
    总结7 ^( M& H  F- d. W  Q
    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流
    - x7 i) Q# D' [! D6 M5 x
    " [+ |. a/ B8 y  \
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-8-29 11:26 , Processed in 0.544857 second(s), 52 queries .

    回顶部