Requests是什么

Requests是用python语言基于urllib编写的,采用的是Apache2 Licensed开源协议的HTTP库 如果你看过上篇文章关于urllib库的使用,你会发现,其实urllib还是非常不方便的,而Requests它会比urllib更加方便,可以节约我们大量的工作。(用了requests之后,你基本都不愿意用urllib了)一句话,requests是python实现的最简单易用的HTTP库,建议爬虫使用requests库。 默认安装好python之后,是没有安装requests模块的,需要单独通过pip安装。

Requests安装

安装方式很简单,直接使用命令安装即可,如下:

pip install requests

也可直接在PyCharm工具中安装,相信大家都已轻车熟路,就忽略了。

Requests详细使用

1.各种请求方式

requests里提供了各种请求方式,比如:get,post,delete,put,具体如下所示:

import requests 
requests.post("http://httpbin.org/post")
requests.put("http://httpbin.org/put")
requests.delete("http://httpbin.org/delete")
requests.get("http://httpbin.org/get")

2.公共方法

在使用requests时,无论你使用的请求方法是get也好,post也罢,他们都会给你返回一个响应的对象,而针对这个对象有一些特定的方法,能够让你进一步解析响应从而得到你想要的数据,如下:

response.json()           # 以json的形式返回响应内容,对象格式为dict
response.content           # 以二进制的形式返回响应内容,对象格式为bytes
response.text            # 以字符串的形式返回响应内容,对象格式为str
response.url             # 返回请求的url
response.status_code        # 返回本次请求的状态码
response.reason           # 返回状态码对应的原因
response.headers          # 返回响应头
response.cookies          # 返回cookice信息
response.raw            # 返回原始响应体
response.encoding         # 返回编码格式

我们了解了基本的请求方式以及响应对象,接下来我们就来以实例再来实践一番,加深印象以及更好的理解。

3.不带参数的get请求

import requests
# 构建一个get请求的对象
response = requests.get('http://www.baidu.com')
# 以字符串的形式返回响应的内容
print response.text

4.带参数的get请求

import requests

# 基本get请求
r = requests.get(url='http://www.baidu.com') # 最基本的GET请求
print(r.status_code) # 获取返回状态
r = requests.get(url='http://www.baidu.com/s', params={'wd': '温一壶清酒 博客园'}) # 带参数的GET请求
print(r.url)
print(r.text) # 打印解码后的返回数据

我们也可以把参数放到一个变量中传递,如下:

import requests

params = {
'wd': '温一壶清酒 博客园'
} # 基本get请求
r = requests.get(url='http://www.baidu.com') # 最基本的GET请求
print(r.status_code) # 获取返回状态
r = requests.get(url='http://www.baidu.com/s', params=params) # 带参数的GET请求
print(r.url)
print(r.text) # 打印解码后的返回数据

5.普通登录post请求

以普通登录方式为例,如下所示:

import requests

# 普通登录
headers = {'Authorization': ''}
r = requests.post(url='XXXX', data={
'username': '', 'password': ''},headers=headers)
print(r.url)
print(r.status_code) # 获取返回状态
print(r.text) # 打印解码后的返回数据

6.basic auth登录post请求

方式一:

import requests
from requests.auth import HTTPBasicAuth # basic auth方式登录
# 方法一
a = HTTPBasicAuth('', '')
r = requests.post(url="XXXXXXX", data={'grant_type': '', 'scope': ''},auth=a) print(r.status_code) # 获取返回状态
print(r.text) # 打印解码后的返回数据

方式二:

import requests

# basic auth方式登录

# 方法二 (只加载requests模块就行)
r = requests.post(url='XXXXXXXX', data={'grant_type': '', 'scope': ''},auth=('', ''))
print(r.status_code) # 获取返回状态
print(r.text) # 打印解码后的返回数据

7.设置请求头

如普通登录post请求方式所示,就添加了headers参数,不同的应用场景,headers里面的参数也就各不同。示例参见第五点即可。

8.证书验证

有些网址访问时,需要校验证书,比如12306官网,我们先来简单访问下,如下:

import requests

# 证书验证
r = requests.get("https://www.12306.cn")
print(r.status_code)
print(r.text)

运行代码,报错如下:

在网上寻找一番,可以得到答案,如下所示:

import requests
import urllib3 # 证书验证
urllib3.disable_warnings()
r = requests.get("https://www.12306.cn", verify=False)
print(r.status_code)
print(r.text)

再次访问,就可以正常进入官网了。

9.json响应数据格式调整

比如下登录操作时,返回的json数据,在控制台中是一行展示,如果数据过多,则不便于查看,如下所示:

使用如下代码实现:

import requests
import json def better_output(json_str):
return json.dumps(json.loads(json_str), indent=4) url = "XXXXXX"
headers = {'Authorization': ''}
request_param = {
'username': '', 'password': ''
}
response = requests.post(url, data=request_param, headers=headers)
print(better_output(response.text))

再次运行代码,查看json数据,如下所示,这样就很方便查看了。

10.动态传参

我们实现登录之后,继续做下一步操作,那就需要传递token了,不然会报401错误,没有权限。接下来就来看下如何实现:

import requests
import json host = '' # json数据转换格式,ensure_ascii显示为中文
def better_output(json_str):
return json.dumps(json.loads(json_str), indent=4, ensure_ascii=False) def login():
# 普通登录
headers = {'Authorization': ''}
data = {
'username': '',
'password': ''
}
url = host + '/token'
r = requests.post(url=url, data=data, headers=headers, verify=False) # 设置全局变量
global token
token = (r.json()["access_token"]) print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
print("+++登录接口响应的状态码为:" + str(r.status_code)) # 获取返回状态
print("+++登录接口响应的数据为:" + better_output(r.text)) # 打印解码后的返回数据
print("+++获取到的token值为:" + token)
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++") login()

将token设置成全局变量,便可在各接口间传递,token已经获取到,将token传到headers中即可,如下:

headers = {
'Content-Type': 'application/json;charset=utf-8',
# token传参
'Authorization': 'Bearer ' + token
}

11.json入参嵌套

方式一:

import requests,json

url = "http://xxx"
headers = {"Content-Type":"application/json","Authorization":"Bearer token值"}
data1 = {"key1":"value1","key2":"value2"}
data = {"params":data1} r = request.post(url = url,data = json.dumps(data),headers = headers)

方式二:

import requests,json

url = "http://xxx"
headers = {"Content-Type":"application/json","Authorization":"Bearer token值"}
data1 = {"key1":"value1","key2":"value2"}
data = {"params":data1} r = request.post(url = url,json = data,headers = headers)

Requests综合实践

如下讲述了这么多,就统一来个综合实践,里面包含了动态传参,添加请求头,json入参嵌套等,如下所示:

import requests
import json host = '' # json数据转换格式,ensure_ascii显示为中文
def better_output(json_str):
return json.dumps(json.loads(json_str), indent=4, ensure_ascii=False) def login():
# 普通登录
headers = {'Authorization': ''}
data = {
'username': '',
'password': '',
}
url = host + '/token'
r = requests.post(url=url, data=data, headers=headers, verify=False) # 设置全局变量
global token
token = (r.json()["access_token"]) print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
print("+++登录接口响应的状态码为:" + str(r.status_code)) # 获取返回状态
print("+++登录接口响应的数据为:" + better_output(r.text)) # 打印解码后的返回数据
print("+++获取到的token值为:" + token)
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++") def search_gender_data():
# 搜索接口
headers = {
'Content-Type': 'application/json;charset=utf-8',
# token传参
'Authorization': 'Bearer ' + token
}
url = host + '/api' r1 = requests.get(url=url, headers=headers)
global gender
gender = r1.json()['values'][0]['code']
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
print("+++搜索接口响应的状态码为:" + str(r1.status_code)) # 获取返回状态
print("+++搜索接口响应的数据为:" + better_output(r1.text))
print("+++获取的性别code为:" + gender)
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++") def create_user():
headers = {
'Content-Type': 'application/json;charset=utf-8',
# token传参
'Authorization': 'Bearer ' + token
}
data = {
"duty": "",
"dutyCode": "",
"rank": "",
"rankCode": "",
"deleted": 'false',
"userId": "",
"employeeId": "",
"position": "测试负责人",
"companyMainPosition": 'true',
} data1 = {
"departmentPath": "",
"directManager": "",
"directManagerId": '',
"directManagerName": "",
"employeeType": '',
"email": "10150001@qq.com",
"mobile": "",
"mobileCode": "",
"countryCode": "CN",
"employeeTypeCode": "",
"userOID": '',
"employeeID": "",
"fullName": "10150001接口新增",
"status": 1001,
"manager": 'false',
"leavingDate": "3018-01-31T16:00:00.000Z",
"gender": "",
"genderCode": gender,
"birthday": "",
"entryTime": "",
"customFormValues": [],
'userJobsDTOs': [data]
}
url = host + '/api'
create_u = requests.post(url=url, json=data1, headers=headers)
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
print("+++创建人员接口url为:" + url)
print("+++创建人员接口响应的状态码为:" + str(create_u.status_code)) # 获取返回状态
print("+++创建人员接口响应的数据为:" + better_output(create_u.text))
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++") if __name__ == '__main__':
# 调用函数
login()
search_gender_data()
create_user()

Requests实践详解希望对有需要的朋友有所帮助,都是些基本的操作,博客书写,也是我自己学习的一种方式。文中描述有误的地方,欢迎批评指正。

Requests实践详解的更多相关文章

  1. python的requests用法详解

    Requests是一个Python语言写的http相关设置或者请求的一个库 安装:pip install Requests或者pip3 install requests 使用的时候要import re ...

  2. python WEB接口自动化测试之requests库详解

    由于web接口自动化测试需要用到python的第三方库--requests库,运用requests库可以模拟发送http请求,再结合unittest测试框架,就能完成web接口自动化测试. 所以笔者今 ...

  3. python接口自动化测试之requests库详解

    前言 说到python发送HTTP请求进行接口自动化测试,脑子里第一个闪过的可能就是requests库了,当然python有很多模块可以发送HTTP请求,包括原生的模块http.client,urll ...

  4. Python爬虫:requests 库详解,cookie操作与实战

    原文 第三方库 requests是基于urllib编写的.比urllib库强大,非常适合爬虫的编写. 安装: pip install requests 简单的爬百度首页的例子: response.te ...

  5. Taffy Web开发,Python Flask实践详解

    1. 前言 最近为Taffy自动化测试框架写了个页面,主要实现了用例管理.执行,测试报告查看管理.发送邮件及配置等功能. 2. 实现细节 页面使用Python Flask +Bootstrap开发,还 ...

  6. Python:requests:详解超时和重试

    网络请求不可避免会遇上请求超时的情况,在 requests 中,如果不设置你的程序可能会永远失去响应.超时又可分为连接超时和读取超时. 连接超时 连接超时指的是在你的客户端实现到远端机器端口的连接时( ...

  7. requests库详解 --Python3

    本文介绍了requests库的基本使用,希望对大家有所帮助. requests库官方文档:https://2.python-requests.org/en/master/ 一.请求: 1.GET请求 ...

  8. Python—requests模块详解

    1.模块说明 requests是使用Apache2 licensed 许可证的HTTP库. 用python编写. 比urllib2模块更简洁. Request支持HTTP连接保持和连接池,支持使用co ...

  9. Taffy自动化测试框架Web开发,Python Flask实践详解

    1. 前言 最近为Taffy自动化测试框架写了个页面,主要实现了用例管理.执行,测试报告查看管理.发送邮件及配置等功能.   本页面适用所有基于taffy/nose框架编写的自动化测试脚本,或基于un ...

随机推荐

  1. 【Redis】缓存穿透与缓存雪崩

    一.缓存雪崩 1.1 缓存雪崩产生的原因 1.2 解决方案 1.3 锁的方式 1.4 消息中间件 1.5 一级和二级缓存 1.6 均摊分配redis key 失效时间 二.缓存穿透 一.缓存雪崩 1. ...

  2. Yum未完成事务问题

    1.安装 yum-complete-transaction [root@linux-node1 ~]# yum -y install yum-utils 2.清除yum缓存 [root@linux-n ...

  3. C++ 基础中的基础 ---- 引用

    C++ 基础中的基础 ---- 引用 引用的概念:引用变量是一个别名,也就是说,它是某个已存在变量的另一个名字.一旦把引用初始化为某个变量,就可以使用该引用名称或变量名称来指向变量.比如: int n ...

  4. 基于通用jar、动态配置、组件编排的会员任务中心系统设计

    # 一.聊聊本文想说什么:   为更好帮助商家的会员快速成长,保持用户活性,完善用户的成长体系,有赞用户中心-会员成长团队基于现有的业务场景,设计了一套较完备任务中心系统.同时也有很多通用技术组件能够 ...

  5. 采用WPF技术,开发OFD电子文档阅读器

    前言 OFD是国家标准版式文档格式,于2016年生效.OFD文档国家标准参见<电子文件存储与交换格式版式文档>.既然是国家标准,OFD随后肯定会首先在政务系统使用,并逐步推向社会各个方面. ...

  6. 61 (OC)* 代理 block 通知 代理 kvo

    1.从源头上理解和区别block和delegate delegate运行成本低,block的运行成本高. block出栈需要将使用的数据从栈内存拷贝到堆内存,当然对象的话就是加计数,使用完或者bloc ...

  7. Java面向对象程序设计第5章1-9

    1.面向对象的主要特征是什么? 三大特征是:封装.继承和多态. 封装:是指将某事物的属性和行为包装到对象中,这个对象只对外公布需要公开的属性和行为,而这个公布也是可以有选择性的公布给其它对象. 继承: ...

  8. Spring入门教程

    Spring新手入门教程,配套下面这两个大神的课程就可以了. 一个是Spring视频教程. 一个是Spring博客教程. https://www.imooc.com/learn/196 http:// ...

  9. JQuery对于动态生成的标签绑定事件失效

    JQuery对整个html文档进行dom操作后,我们要想动态绑定事件,有两种方法 1.在进行dom操作时,在标签中写上onclick="afun()" 2.利用document的操 ...

  10. npm install 时间很长解决方案

    国外镜像站很慢,所以我们可以更换为国内的镜像站 首先可以get命令查看registry npm congfig get registry 如果你没有变更果regustry你的结果应该会是这样的 也就是 ...