Python requests模块实例用法


Posted in Python onFebruary 11, 2019

1、Requests模块说明

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

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

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

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

2、Requests模块安装

点此下载

然后执行安装

$ python setup.py install

个人推荐使用pip安装

pip install requests

也可以使用easy_install安装

easy_install requests

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

3、Requests模块简单入门

#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)

xml请求

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

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

if __name__=='__main__':
 
 headers = {'Content-type': 'text/xml'}
 XML = '<?xml version="1.0" encoding="utf-8"?><soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Body><Request xmlns="http://tempuri.org/"><jme><JobClassFullName>WeChatJSTicket.JobWS.Job.JobRefreshTicket,WeChatJSTicket.JobWS</JobClassFullName><Action>RUN</Action><Param>1</Param><HostIP>127.0.0.1</HostIP><JobInfo>1</JobInfo><NeedParallel>false</NeedParallel></jme></Request></soap:Body></soap:Envelope>'
 url = 'http://jobws.push.mobile.xxxxxxxx.com/RefreshWeiXInTokenJob/RefreshService.asmx'
 r = requests.post(url,headers=headers,data=XML)
 #r.encoding = 'utf-8'
 data = r.text
 print data
Python 相关文章推荐
python2.7删除文件夹和删除文件代码实例
Dec 18 Python
跟老齐学Python之大话题小函数(2)
Oct 10 Python
利用Python抓取行政区划码的方法
Nov 28 Python
python3安装pip3(install pip3 for python 3.x)
Apr 03 Python
深入浅析Python中list的复制及深拷贝与浅拷贝
Sep 03 Python
Python人脸识别第三方库face_recognition接口说明文档
May 03 Python
Pycharm 文件更改目录后,执行路径未更新的解决方法
Jul 19 Python
使用python3批量下载rbsp数据的示例代码
Dec 20 Python
对tensorflow中cifar-10文档的Read操作详解
Feb 10 Python
基于FME使用Python过程图解
May 13 Python
Python 使用双重循环打印图形菱形操作
Aug 09 Python
python3.7 openpyxl 在excel单元格中写入数据实例
Sep 01 Python
说说如何遍历Python列表的方法示例
Feb 11 #Python
python按照多个条件排序的方法
Feb 08 #Python
python 使用pandas计算累积求和的方法
Feb 08 #Python
对Python中的条件判断、循环以及循环的终止方法详解
Feb 08 #Python
解决Pandas的DataFrame输出截断和省略的问题
Feb 08 #Python
对Python之gzip文件读写的方法详解
Feb 08 #Python
Python第三方库h5py_读取mat文件并显示值的方法
Feb 08 #Python
You might like
PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
2009/08/07 PHP
Linux下PHP安装mcrypt扩展模块笔记
2014/09/10 PHP
JavaScript的面向对象(二)
2006/11/09 Javascript
div层的移动及性能优化
2010/11/16 Javascript
js实现二代身份证号码验证详解
2014/11/20 Javascript
JS 对象属性相关(检查属性、枚举属性等)
2015/04/05 Javascript
jquery+html5烂漫爱心表白动画代码分享
2015/08/24 Javascript
jQuery获取table行数并输出单元格内容的实现方法
2016/06/30 Javascript
Vue组件BootPage实现简单的分页功能
2016/09/12 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
Vuex简单入门
2017/04/19 Javascript
详解基于 Nuxt 的 Vue.js 服务端渲染实践
2017/10/24 Javascript
vue的全局提示框组件实例代码
2018/02/26 Javascript
vue 的点击事件获取当前点击的元素方法
2018/09/15 Javascript
vue实现条件判断动态绑定样式的方法
2018/09/29 Javascript
30分钟精通React今年最劲爆的新特性——React Hooks
2019/03/11 Javascript
微信小程序开发实现的选项卡(窗口顶部/底部TabBar)页面切换功能图文详解
2019/05/14 Javascript
Electron-vue开发的客户端支付收款工具的实现
2019/05/24 Javascript
解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题
2020/09/02 Javascript
JS中循环遍历数组的四种方式总结
2021/01/23 Javascript
[46:44]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD BO3 第二场 3月7日
2021/03/11 DOTA
python抽象基类用法实例分析
2015/06/04 Python
解决Python字典写入文件出行首行有空格的问题
2017/09/27 Python
opencv改变imshow窗口大小,窗口位置的方法
2018/04/02 Python
python3 requests中使用ip代理池随机生成ip的实例
2018/05/07 Python
python三方库之requests的快速上手
2019/03/04 Python
python中 * 的用法详解
2019/07/10 Python
使用Python防止SQL注入攻击的实现示例
2020/05/21 Python
Python抓包并解析json爬虫的完整实例代码
2020/11/03 Python
HTML5 HTMLCollection和NodeList的区别详解
2020/04/29 HTML / CSS
navabi英国:设计师大码女装
2019/06/25 全球购物
日语专业个人的求职信
2013/12/03 职场文书
库房主管岗位职责
2013/12/31 职场文书
大型活动组织方案
2014/05/10 职场文书
2014年六一儿童节演讲稿
2014/05/23 职场文书
Vue过滤器(filter)实现及应用场景详解
2021/06/15 Vue.js