• 爬虫-request(3)


    import requests
    
    # GET请求
    r = requests.get('http://httpbin.org/get')
    print(r.status_code, r.reason)
    print('GET请求', r.text)
    # 带参数的GET请求
    r = requests.get('http://httpbin.org/get', params={'a': '1', 'b': '2'})
    print('带参数的GET请求', r.json())
    
    #POST请求
    r = requests.post('http://httpbin.org/post', data={'a': '1'})
    print('POST请求', r.json())
    
    # 自定义headers请求
    ua = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_0) ' 
         'AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77' 
         ' Safari/537.36'
    headers = {'User-Agent': ua}
    r = requests.get('http://httpbin.org/headers', headers=headers)
    print('自定义headers请求', r.json())
    
    # 带cookies的请求
    cookies = dict(userid='123456', token='xxxxxxxxxxxxxxxxxxxx')
    r = requests.get('http://httpbin.org/cookies', cookies=cookies)
    print('带cookies的请求', r.json())
    
    # Basic-auth认证请求
    r = requests.get('http://httpbin.org/basic-auth/guye/123456', auth=('guye', '123456'))
    print('Basic-auth认证请求', r.json())
    
    # 主动抛出状态码异常
    bad_r = requests.get('http://httpbin.org/status/404')
    print(bad_r.status_code)
    bad_r.raise_for_status()
    
    #使用requests.Session对象请求
    # 创建一个Session对象
    s = requests.Session()
    # session对象会保存服务器返回的set-cookies头信息里面的内容
    s.get('http://httpbin.org/cookies/set/userid/123456789')
    s.get('http://httpbin.org/cookies/set/token/xxxxxxxxxxxxxxxxxx')
    # 下一次请求会将本地所有的cookies信息自动添加到请求头信息里面
    r = s.get('http://httpbin.org/cookies')
    print('检查session中的cookies', r.json())
    
    
    # 在requests中使用代理
    print('不使用代理:', requests.get('http://httpbin.org/ip').json())
    print('使用代理:', requests.get(
        'http://httpbin.org/ip',
        proxies={'http': 'http://iguye.com:41801'}
    ).json())
    
    r = requests.get('http://httpbin.org/delay/4', timeout=5)
    print(r.text)

    request&urllib的区别

    urlencode不能直接处理unicode对象,所以如果是unicode,需要先编码,有unicode转到utf8,举例:
    urllib.urlencode (u'bl'.encode('utf-8')) 
    
    Requests支持HTTP连接保持和连接池,支持使用cookie保持会话,支持文件上传,支持自动确定响应内容的编码,支持国际化的 URL 和 POST 数据自动编码。
    
    IV. requests不是python自带的库,需要另外安装 easy_install or pip install
    V. requests缺陷:直接使用不能异步调用,速度慢(from others)。官方的urllib可以替代它。
  • 相关阅读:
    java反射笔记
    Java常见异常类型
    找了这么多毕业设计题目,反而不知道选什么了
    C#中Trim()、TrimStart()、TrimEnd()的用法
    JS bom对象
    HTML随笔
    Sublim text3汉化
    11G RAC ORA-32701
    DB_LINK
    ORA-16957: SQL Analyze time limit interrupt
  • 原文地址:https://www.cnblogs.com/topass123/p/13277384.html
Copyright © 2020-2023  润新知