QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4155|回复: 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

    8 E1 G9 t7 Y. V0 j/ i
    Python爬虫常用小技巧之设置代理IP

    - t: c* |8 I1 b9 D+ t. {% Q+ d" z2 T4 i: a: l. ?4 i9 J
    设置代理IP的原因$ q* T) a1 t' C& P. Q  Y) |3 ?
    我们在使用Python爬虫爬取一个网站时,通常会频繁访问该网站。假如一个网站它会检测某一段时间某个IP的访问次数,如果访问次数过多,它会禁止你的访问。所以你可以设置一些代理服务器来帮助你做工作,每隔一段时间换一个代理,这样便不会出现因为频繁访问而导致禁止访问的现象。" g/ E3 c0 Q8 n" c& H- W
    我们在学习Python爬虫的时候,也经常会遇见所要爬取的网站采取了反爬取技术导致爬取失败。高强度、高效率地爬取网页信息常常会给网站服务器带来巨大压力,所以同一个IP反复爬取同一个网页,就很可能被封,所以下面这篇文章讲述一个爬虫技巧,设置代理IP
    6 E; S! R2 ~( C5 B. ^1 V: s代理的获取有很多方式,网上有很多免费的可以去爬取一些试试,但是免费的代理使用起来也是 很吃力的。还有就是现在网上有很多的代理供应商,可以在网上寻找下,然后找家靠谱的使用。毕竟网络太大了,代理供应商肯定也是参差不齐的,所以找到合适的代理还是需要花点时间的。在这里我就是使用了我们长期使用的一家质量好的代理,亿牛云代理,而且是使用的他们的爬虫代理(动态转发)和一般的api模式不一样。这种更简单更方便,对于懒人来说绝对是最佳选择。
    & b* [7 v& F) C4 U9 w' n具体代码的使用! C( O0 `/ w% ?( V, `# g' s
    #! -*- encoding:utf-8 -*-
    * \% l/ r  L* x8 {8 h8 s1 ?
    3 h+ s! C7 v% E( {5 C% }8 N        import requests
    7 K3 G; A7 r/ s1 l7 i* f        import random/ B, P4 M! m% p; P) Q: \8 F

    $ h8 B6 ~5 u6 l* w. ^! u        # 要访问的目标页面
    + [6 D6 X: B- H# {7 Z/ C        targetUrl = "http://httpbin.org/ip", r6 \9 r" S) i$ w# g  P0 U1 A, E
    / `; ~2 Q! Z  N
            # 要访问的目标HTTPS页面2 H$ }. Y4 f0 n% X; ?' t# s$ N
            # targetUrl = "https://httpbin.org/ip"+ W. q! l$ j& G) U7 r
    # b/ W+ Q7 D; i' u: J' {0 N
            # 代理服务器* a7 c1 w0 {0 K9 Y8 [
            proxyHost = "t.16yun.cn"! X( J4 f; `% u- J- o& a2 ^
            proxyPort = "31111"' w/ R7 v2 p& a6 `9 h. P" {
    3 a% W4 D7 A! N6 n* F. L
            # 代理隧道验证信息% J/ r) L1 E" {. f- u, j" X; O3 y
            proxyUser = "username"
    # }  i7 e9 H' }3 ?9 A        proxyPass = "password"7 p5 a& d4 a( P, g+ A+ _
    ' X, S+ `: |% I
            proxyMeta = "http://%(user)s:%(pass)s@%(host)s:%(port)s" % {
    2 ]$ K! r8 Y( p; s* c. U            "host" : proxyHost,
    $ q* H8 z: w0 |            "port" : proxyPort,7 R9 v4 R  H; P( H& `
                "user" : proxyUser,
    ; ]# ?3 m" ?2 U' \( m            "pass" : proxyPass,$ I8 y( B- C* u
            }- G, Q$ ^- ^1 ^2 f% c5 c7 h; H

    . r1 y) E  f3 j) n7 Y3 W7 T        # 设置 http和https访问都是用HTTP代理
    / S: c5 e8 O! H. a$ Y        proxies = {
    ; f& N; l  G/ N$ h& I5 s  Y7 z8 F            "http"  : proxyMeta,( R7 j8 U; m; V0 r; r
                "https" : proxyMeta,
    " O2 M* P( E' T: M# {        }
    4 v4 B) M& m! _( L4 _- P/ `% j3 ^8 s! ?: M4 j0 R; e" s! I! s
    ) o) g$ I6 B+ |
            #  设置IP切换头' R  K  S; |7 @
            tunnel = random.randint(1,10000)( s1 Y4 C# f. j  {* J. @
            headers = {"Proxy-Tunnel": str(tunnel)}! `' j0 i# w7 Q3 B0 I4 \
            resp = requests.get(targetUrl, proxies=proxies, headers=headers)
    ) ?% |7 ]1 O. g2 c/ ^
    ( h  Y3 k9 j5 G  f2 b* @        print resp.status_code
    3 t5 q* L' z; p( |; r3 [" T- E        print resp.text
    ! B# i- t, W. M! K* `3 j总结* }7 f1 W9 E- p3 Q  R# O
    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流
    8 d7 g5 n6 x4 v& N4 b6 o5 w# g1 [3 }& q9 t! w9 n) Z
    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 16:36 , Processed in 0.893293 second(s), 51 queries .

    回顶部