码迷,mamicode.com
首页 > 编程语言 > 详细

Python requests模块学习笔记

时间:2015-01-16 18:44:38      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:

Requests 是使用 Apache2 Licensed 许可证的 HTTP 库。用 Python 编写,真正的为人类着想。

Python 标准库中的 urllib2 模块提供了你所需要的大多数 HTTP 功能,但是它的 API 太渣了。它是为另一个时代、另一个互联网所创建的。它需要巨量的工作,甚至包括各种方法覆盖,来完成最简单的任务。

在Python的世界里,事情不应该这么麻烦。

Requests 使用的是 urllib3,因此继承了它的所有特性。Requests 支持 HTTP 连接保持和连接池,支持使用 cookie 保持会话,支持文件上传,支持自动确定响应内容的编码,支持国际化的 URL 和 POST 数据自动编码。现代、国际化、人性化。

(以上转自Requests官方文档)

 

1. 安装

点此下载

然后执行安装

$ python setup.py install

个人推荐使用pip安装

pip install requests

也可以使用easy_install安装

easy_install requests

尝试在IDE中import requests,如果没有报错,那么安装成功。

2. 简单入门

#HTTP请求类型
#get类型
r = requests.get(https://github.com/timeline.json)
#post类型
r = requests.post("http://m.ctrip.com/post")
#put类型
r = requests.put("http://m.ctrip.com/put")
#delete类型
r = requests.delete("http://m.ctrip.com/delete")
#head类型
r = requests.head("http://m.ctrip.com/head")
#options类型
r = requests.options("http://m.ctrip.com/get")

#获取响应内容
print r.content #以字节的方式去显示,中文显示为字符
print r.text #以文本的方式去显示

#URL传递参数
payload = {keyword: 日本, salecityid: 2}
r = requests.get("http://m.ctrip.com/webapp/tourvisa/visa_list", params=payload) 
print r.url #示例为http://m.ctrip.com/webapp/tourvisa/visa_list?salecityid=2&keyword=日本

#获取/修改网页编码
r = requests.get(https://github.com/timeline.json)
print r.encoding
r.encoding = utf-8

#json处理
r = requests.get(https://github.com/timeline.json)
print r.json() #需要先import json    

#定制请求头
url = http://m.ctrip.com
headers = {User-Agent : Mozilla/5.0 (Linux; Android 4.2.1; en-us; Nexus 4 Build/JOP40D) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.166 Mobile Safari/535.19}
r = requests.post(url, headers=headers)
print r.request.headers

#复杂post请求
url = http://m.ctrip.com
payload = {some: data}
r = requests.post(url, data=json.dumps(payload)) #如果传递的payload是string而不是dict,需要先调用dumps方法格式化一下

#post多部分编码文件
url = http://m.ctrip.com
files = {file: open(report.xls, rb)}
r = requests.post(url, files=files)

#响应状态码
r = requests.get(http://m.ctrip.com)
print r.status_code
    
#响应头
r = requests.get(http://m.ctrip.com)
print r.headers
print r.headers[Content-Type]
print r.headers.get(content-type) #访问响应头部分内容的两种方式
    
#Cookies
url = http://example.com/some/cookie/setting/url
r = requests.get(url)
r.cookies[example_cookie_name]    #读取cookies
    
url = http://m.ctrip.com/cookies
cookies = dict(cookies_are=working)
r = requests.get(url, cookies=cookies) #发送cookies

#设置超时时间
r = requests.get(http://m.ctrip.com, timeout=0.001)

#设置访问代理
proxies = {
           "http": "http://10.10.10.10:8888",
           "https": "http://10.10.10.100:4444",
          }
r = requests.get(http://m.ctrip.com, proxies=proxies)

3. 示例

#!/user/bin/env python
#coding=utf-8
import requests
import json

class url_request():
    def __init__(self):
            """ init """    

if __name__==__main__:
    headers = {User-Agent : Mozilla/5.0 (Linux; Android 4.2.1; en-us; Nexus 4 Build/JOP40D) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.166 Mobile Safari/535.19}
    payload = {CountryName:中国,
               ProvinceName:陕西省,
               L1CityName:汉中,
               L2CityName:城固,
               TownName:‘‘,
               Longitude:107.33393,
               Latitude:33.157131,
               Language:CN
               }
    r = requests.post("http://www.xxxxxx.com/CityLocation/json/LBSLocateCity",headers=headers,data=payload)
    #r.encoding = ‘utf-8‘
    data=r.json()
    print r.text
    if r.status_code!=200:
        print "LBSLocateCity API Error " + str(r.status_code)
    print data[CityEntities][0][CityID] #打印返回json中的某个key的value
    print data[ResponseStatus][Ack]

 

参考文档:

http://cn.python-requests.org/en/latest/

http://docs.python-requests.org/en/latest/user/quickstart.html

Python requests模块学习笔记

标签:

原文地址:http://www.cnblogs.com/tangdongchu/p/4229049.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!