Requests库学习

  • 请求豆瓣电影的前250,然后获取请求到内容的属性

      import requests
    
      r = requests.get('https://movie.douban.com/top250')
      print type(r)
      print r.status_code
      print r.encoding
      #print r.text
      print r.cookies
  • requests的请求方式
    • get()
    • post()
    • put()
    • delete()
    • head()
    • options()
get()请求:
  • requests请求时附加参数
    ```
    import requests

    payload = {'key1': 'value1', 'key2': 'value2'}
    r = requests.get("http://httpbin.org/get", params=payload)
    print r.url
    ```

  • 请求json文件
    • json文件内容如下:
    ["foo", "bar", {
      "foo": "bar"
    }]
    • requests请求json
        import requests
        r = requests.get("a.json")
        print r.text
        print r.json()
    • 运行结果
      [u'foo', u'bar', {u'foo': u'bar'}]
  • 获取来自服务器的原始套接字响应(在初始请求中设置 stream=True,用r.raw取得)

    r = requests.get('https://github.com/timeline.json', stream=True)
    r.raw
    <requests.packages.urllib3.response.HTTPResponse object at 0x101194810>
    r.raw.read(10)
    '\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x03'
  • 请求时传入header参数
    ```
    import requests

    payload = {'key1': 'value1', 'key2': 'value2'}
    headers = {'content-type': 'application/json'}
    r = requests.get("http://httpbin.org/get", params=payload, headers=headers)
    print r.url
    ```

post请求
  • 对于 POST 请求来说,我们一般需要为它增加一些参数。那么最基本的传参方法可以利用 data 这个参数。
    ```
    import requests

    payload = {'key1': 'value1', 'key2': 'value2'}
    r = requests.post("http://httpbin.org/post", data=payload)
    print r.text
    * 运行结果
    {
    "args": {},
    "data": "",
    "files": {},
    "form": {
    "key1": "value1",
    "key2": "value2"
    },
    "headers": {
    "Accept": "/",
    "Accept-Encoding": "gzip, deflate",
    "Content-Length": "23",
    "Content-Type": "application/x-www-form-urlencoded",
    "Host": "httpbin.org",
    "User-Agent": "python-requests/2.9.1"
    },
    "json": null,
    "url": "http://httpbin.org/post"
    }
    ```

cookies

  • 如果一个响应中包含了cookie,那么我们可以利用 cookies 变量来拿到
    ```
    import requests

    url = 'http://example.com'
    r = requests.get(url)
    print r.cookies
    print r.cookies['example_cookie_name']
    ```
    • 运行结果
      '{"cookies": {"cookies_are": "working"}}'

转载于:https://www.cnblogs.com/lhfen/p/6197425.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值