QQ登录

只需要一步,快速开始

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

    4 i) u: i, D5 ~! x/ \( |
    Python爬虫常用小技巧之设置代理IP

    2 a$ L) f4 P8 {' `/ ?3 r3 V3 F, g' }* }# ]7 \# r5 y
    设置代理IP的原因
    + i8 s  T" [" Z" ~8 B: e我们在使用Python爬虫爬取一个网站时,通常会频繁访问该网站。假如一个网站它会检测某一段时间某个IP的访问次数,如果访问次数过多,它会禁止你的访问。所以你可以设置一些代理服务器来帮助你做工作,每隔一段时间换一个代理,这样便不会出现因为频繁访问而导致禁止访问的现象。3 F# t, Q5 I( p1 L5 `! [6 b5 c2 b- m
    我们在学习Python爬虫的时候,也经常会遇见所要爬取的网站采取了反爬取技术导致爬取失败。高强度、高效率地爬取网页信息常常会给网站服务器带来巨大压力,所以同一个IP反复爬取同一个网页,就很可能被封,所以下面这篇文章讲述一个爬虫技巧,设置代理IP
    ! ?' L9 v+ R0 |% c3 p6 H代理的获取有很多方式,网上有很多免费的可以去爬取一些试试,但是免费的代理使用起来也是 很吃力的。还有就是现在网上有很多的代理供应商,可以在网上寻找下,然后找家靠谱的使用。毕竟网络太大了,代理供应商肯定也是参差不齐的,所以找到合适的代理还是需要花点时间的。在这里我就是使用了我们长期使用的一家质量好的代理,亿牛云代理,而且是使用的他们的爬虫代理(动态转发)和一般的api模式不一样。这种更简单更方便,对于懒人来说绝对是最佳选择。
    ' Z% x8 C$ O. e6 {, y# b0 {8 D( _具体代码的使用
    9 X! K4 b/ b( Q+ w! ?% I8 g#! -*- encoding:utf-8 -*-
    ) k, ^+ f+ m% T
    $ R; o' u+ c8 y& f8 ?        import requests- W. d% Y8 h2 G! v
            import random
    9 `$ q6 Q$ V$ w- \! O/ e  Q$ `2 s9 R% a/ U9 W9 S) s
            # 要访问的目标页面
    ( X  a$ p- z$ }! R3 r        targetUrl = "http://httpbin.org/ip"
    ! z# A1 R  W. C& e: [" l
    * ?2 R3 X: [7 \$ B! g1 _/ o& j        # 要访问的目标HTTPS页面
    . P2 O5 x, O4 @        # targetUrl = "https://httpbin.org/ip"$ a7 [. f' P/ Z

    # G( G! E& b4 C, q        # 代理服务器
    " }7 ?" Q# x! U& p* N        proxyHost = "t.16yun.cn"
    ! p, }. l5 H6 S7 n9 D% b        proxyPort = "31111"5 {/ P4 z2 \6 _; J6 ~

    2 W0 R* P# q+ Q$ ^8 R3 i        # 代理隧道验证信息: y1 _0 [) R  f- ?9 R5 y9 `) H
            proxyUser = "username"( O' V+ `* m* T* t7 O5 i9 X
            proxyPass = "password"0 S9 }) r  H' k" w; v

    / b) `7 W" {. ]8 F+ h- N/ t( ^        proxyMeta = "http://%(user)s:%(pass)s@%(host)s:%(port)s" % {
    + D# M9 U( t3 A$ g( {! a            "host" : proxyHost,
    1 g  `) K( v( ^8 p            "port" : proxyPort,
      ^" W. U6 ?$ T; I            "user" : proxyUser,
    & i3 ^% F: J& R4 f/ b0 G            "pass" : proxyPass,
    4 a; z9 A7 a! w. a( {        }. ?: z* Q7 y! i+ F

    ! Y# v% q1 I$ j0 j8 H  L  I        # 设置 http和https访问都是用HTTP代理, P, r4 B* D8 \; A
            proxies = {
    3 {2 S- v0 n8 p( t* |0 g            "http"  : proxyMeta,
    ( B; F4 E7 c, Q# b% {5 d/ p            "https" : proxyMeta,9 E. C3 [$ q  M$ g8 d/ s
            }! h: N/ U- L, q8 g; s
    . x( W) V) X$ ?$ s
    7 y5 t' g; @: b9 o& B2 h- t
            #  设置IP切换头
      B/ Z, L) T" D; q5 T7 d; D" b        tunnel = random.randint(1,10000)
    5 `- t( @8 }/ `) {4 x" l0 x/ c        headers = {"Proxy-Tunnel": str(tunnel)}
    " h; q+ _' i. m/ G& C2 w; `        resp = requests.get(targetUrl, proxies=proxies, headers=headers)
    ' H9 B2 @; R0 C2 x9 X# H- n# A6 [4 o9 U# o3 ^8 c1 `
            print resp.status_code
    1 w, r& P; A% T; c' J/ `        print resp.text- }, b8 W7 h1 e3 }+ h
    总结
    9 B8 ~0 X- _$ j: q) j以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流
    . A" u- ^: t; }& Y1 P8 H5 y* |6 ~1 ]. j! i  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, 2026-6-3 01:10 , Processed in 0.414588 second(s), 51 queries .

    回顶部