QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4154|回复: 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
    3 J# }. |# @7 N& v9 }4 O# K
    Python爬虫常用小技巧之设置代理IP

    0 T. V: g2 G  G% |: O( H
    2 o0 g- B. j; Q/ g. j' }( k设置代理IP的原因1 B5 E# {$ F' _  h" [+ z3 w- F
    我们在使用Python爬虫爬取一个网站时,通常会频繁访问该网站。假如一个网站它会检测某一段时间某个IP的访问次数,如果访问次数过多,它会禁止你的访问。所以你可以设置一些代理服务器来帮助你做工作,每隔一段时间换一个代理,这样便不会出现因为频繁访问而导致禁止访问的现象。. g( A& y* D7 v( t6 m6 u4 i8 R
    我们在学习Python爬虫的时候,也经常会遇见所要爬取的网站采取了反爬取技术导致爬取失败。高强度、高效率地爬取网页信息常常会给网站服务器带来巨大压力,所以同一个IP反复爬取同一个网页,就很可能被封,所以下面这篇文章讲述一个爬虫技巧,设置代理IP& u# {7 B! c' v. _3 N  H
    代理的获取有很多方式,网上有很多免费的可以去爬取一些试试,但是免费的代理使用起来也是 很吃力的。还有就是现在网上有很多的代理供应商,可以在网上寻找下,然后找家靠谱的使用。毕竟网络太大了,代理供应商肯定也是参差不齐的,所以找到合适的代理还是需要花点时间的。在这里我就是使用了我们长期使用的一家质量好的代理,亿牛云代理,而且是使用的他们的爬虫代理(动态转发)和一般的api模式不一样。这种更简单更方便,对于懒人来说绝对是最佳选择。
    1 S/ t6 k' {+ v! X* ~4 A( p8 O. p具体代码的使用4 `4 H/ T* I) P& n- y
    #! -*- encoding:utf-8 -*-  ?9 \/ ~1 o9 @: D! P- s9 K7 u
    6 B) ?* k" O$ G4 x: F
            import requests
    * E# F* K3 ]/ S& T9 e        import random0 @- Q  g! D! J
    / {& w! Q) C9 ]: t
            # 要访问的目标页面9 `; J; k$ M9 L* P  ^9 f* g) k
            targetUrl = "http://httpbin.org/ip"
    9 _' D: B# j5 C* L# F* G. k6 W! u5 t- w" e8 k) C" @
            # 要访问的目标HTTPS页面
    , Z# [& ~7 B# c* t& m8 S& \        # targetUrl = "https://httpbin.org/ip"
    ! z7 |: l1 C& R( ~% O* k) ]/ r
    6 d) q2 M" X1 U        # 代理服务器
    , c# X% H& D5 H5 w4 B2 N        proxyHost = "t.16yun.cn"4 I/ d) Y! X, m* h3 ]8 E2 e
            proxyPort = "31111"1 H: C, [) `/ M( A9 }. n8 F
    * T1 {( G& ^/ Z+ e' c7 X4 P8 F
            # 代理隧道验证信息
    8 Q& X3 Z; Z' o$ ]        proxyUser = "username"
    1 u2 E4 F6 C# N1 B' F+ `        proxyPass = "password": [6 E, k/ K  e5 C2 U
    $ O( F$ ^7 y, Q  P: K
            proxyMeta = "http://%(user)s:%(pass)s@%(host)s:%(port)s" % {1 ?' `% ?, j, H" a4 w; \6 J" D: }
                "host" : proxyHost,: T% h  l( ?% y/ Z& O
                "port" : proxyPort,/ C$ \9 a  I8 z$ |/ p3 O
                "user" : proxyUser,
    - O( H4 d" w- m5 H            "pass" : proxyPass,
    , a" x  J* J. v, N) P" b        }
    % B* @  V9 m- P9 U% D  M
    - j# D8 H$ S# ~7 i5 t, g        # 设置 http和https访问都是用HTTP代理
    ' W7 K# B+ m# _! [9 E        proxies = {
    5 x+ s9 t: S+ P& L0 s5 s            "http"  : proxyMeta,4 x5 q/ x' X- {$ `) v0 D, a* ]5 e
                "https" : proxyMeta,
    + J$ D! F' W5 y7 g        }
    7 M6 V" w, u9 t" \4 a% i1 t& M
    * v& j- r3 Y# [% ~4 i$ x: w& ?: N8 X& V6 _# [0 K
            #  设置IP切换头
    0 S1 x6 D9 w! R# n9 e* H+ o        tunnel = random.randint(1,10000)) p2 D5 _6 `1 ^7 n( z( j
            headers = {"Proxy-Tunnel": str(tunnel)}
    + w6 @" |  Y' @/ B+ d. p7 c        resp = requests.get(targetUrl, proxies=proxies, headers=headers)
    ( M3 t$ o$ t9 w# h) b) t
    7 o% V. r) i" H- r' i        print resp.status_code, l7 P5 S2 e4 u% z/ r) m: B  D
            print resp.text$ S2 X; J% U) D9 i/ [6 ]# ^
    总结
    - j: p) K( I+ d9 t$ {  C: w3 J以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流
    , \1 w, V6 W) u
    ! {8 X% M, m. w
    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-19 14:33 , Processed in 0.416215 second(s), 50 queries .

    回顶部