首页 > 其他分享 >requests模块

requests模块

时间:2023-04-16 20:26:07浏览次数:32  
标签:name url res request 模块 print requests type

1、介绍

requests是python用于处理http/https的一个第三方库,需要pip安装。

2、request函数

import requests
res = requests.request(method='GET', url='https://www.baidu.com/');
  • request是一个函数,method和url参数必须给定
  • res的类型为<class ‘requests.models.Response’>

(1)method

  • 该参数必须设置,一般是GET、POST、PUT、DELETE、PATCH、OPTIONS、HEAD。也可以是小写,或者混杂
  • method设置错误,比如为GE,不影响请求的发送。http的请求方法就为设置的错误值的大写,由服务器决定如何处理。如果对方法有限定可能会响应302,没有限定则可能会响应200。
  • res.request.method的值即这里设置的字符串。如果是小写的get,会自动转为大写。

(2)url

  • 该参数必须设置,而且需要包括协议部分
  • 如果域名不存在http或者https服务,会报错
  • 可以直接处理https,也可以是http

(3)params

q = {'name':'zz'}
# q = {'name':'zz','age':12}
# q_2 = [('name','zz'),('age',22)]
# q_3 = 'name=xx&age=12'
res_1 = requests.request(method='GET', url='https://www.baidu.com', params=q)
# https://www.baidu.com?name=zz
res_2 = requests.request(method='GET', url='https://www.baidu.com?name=12', params=q)
# https://www.baidu.com?name=12&name=zz

作用:设置url中的请求参数,类型可以为字典或者元组的列表,或者字符串

字典中的值会拼接到url中的params部分,如果未有参数,则先会添加?。如果已有参数,则直接追加,注意不会检查已有参数是否已经重名

(4)data

data_1 = 'abcd'	# abcd
data_2 = {'name':'zz','age':12}	# name=zz&age=12
data_3 = [('name','zz'),('age',12)] # name=zz&age=12

作用:设置body部分携带的数据,类型可以为字符串、元组的列表和字典

(5)json

json_1 = 'abcd'	# b'"abcd"'
json_2 = {'name':'zz','age':12}	# b'{"name": "zz", "age": 12}'
json_3 = [('name','zz'),('age',12)]	# b'[["name", "zz"], ["age", 12]]'

作用:设置body部分携带的数据,以json格式发送,类型可以为字符串、元组的列表和字典

(6)headers

headers = {'User-Agent':'zz','age':'12', 'Cookie':'name=zz; age=123'}

作用:设置请求的头部字段,类型为字典,并且字典元素的键和值都必须是str类型,否则报错

request方法自身默认会设置一些http请求头部字段,在指定headers参数时,会进行判断是否已设置字段,判断不区分大小写,如果重复则覆盖,如果不重复则追加字段

如果覆盖,并且新设置的键和值替代之前的键和值。主要注意其键的大小写以新设置的为准

headers的键可以任意设置,而非一定要是http协议规定的,同时可以直接在其中设置cookie

(7)cookies

cookies = {'name':'zz','age':'12'}

作用:设置请求携带的cookie,类型为字典,并且字典元素的键和值都必须是str类型,否则报错

(8)files

upload_files = {'file': open('report.xls', 'rb')}
r = requests.post(url, files=upload_files)

作用:上传文件

在读取文件时,注意务必使用'rb'即二进制模式读取,这样获取的bytes长度才是文件的长度。

3、特定请求方法

def get(url, params=None, **kwargs)
def options(url, **kwargs)
def head(url, **kwargs)
def post(url, data=None, json=None, **kwargs)
def put(url, data=None, **kwargs)
def patch(url, data=None, **kwargs)
def delete(url, **kwargs)

4、请求信息

print(res.request.url, type(res.request.url))
print(res.request.method, type(res.request.method))
print(res.request.headers, type(res.request.headers))
print(res.request.body, type(res.request.body))
print(res.request.hooks, type(res.request.hooks))

(1)url和method

这两个属性类型为字符串,并且一个正常的request方法调用其值不为空

(2)headers

1)从值的形式上来说,是字典形式,键和值都是字符串。但实际的数据类型为<class ‘requests.structures.CaseInsensitiveDict’>

2)其值往往也不为空,模块代码会默认设置和携带一些头部

3)以下四种均输出,证明大小写不敏感

if 'user-agent' in res.request.headers:
    print(1)
if 'user-agent' in res.request.headers.keys():
    print(12)
if 'User-Agent' in res.request.headers:
    print(13)
if 'User-Agent' in res.request.headers.keys():
    print(134)

4)对headers直接在pyqt等要求参数为字符串str的场景中必须使用str函数进行强转

(3)body

如果没有设置data或者json,其值为None,类型为NoneType

在pyqt等要求参数为字符串str的场景中必须使用str函数进行强转

如果设置了data或者json,其值为str类型

(4)hooks

属性类型为字典,字典只有一个元素,其键为response,值为一个列表,列表的元素为定义的钩子函数

在pyqt等要求参数为字符串str的场景中必须使用str函数进行强转

{'response': [<function print_url at 0x0000026BC320F0D0>, <function change_url at 0x0000026BC35D0700>]}

5、响应信息

(1)响应

print(res, type(res))
# <Response [302]> <class 'requests.models.Response'>
  • 请求执行之后会返回一个响应对象

(2)headers

作用:获取响应的头部字段信息

其类似dict类型,可用通过索引取值,或者str函数转换,或者调用dict类型的方法

如果取值没有该字段,会报错

print(res.headers, type(res.headers))
# {'Server': 'nginx/1.15.5', 'Date': 'Sat, 21 Aug 2021 21:10:41 GMT', 'Content-Type': 'text/html', 'Content-Length': '157', 'Connection': 'keep-alive'} <class 'requests.structures.CaseInsensitiveDict'>
print(res.headers['Server'])
print(res.headers.values())

(3)url、raw、ok、is_redirect、reason、status_code

print(res.url, type(res.url))
print(res.raw, type(res.raw))
print(res.ok, type(res.ok))
print(res.is_redirect, type(res.is_redirect))
print(res.reason, type(res.reason))
print(res.status_code, type(res.status_code))
'''
https://www.baidu.com/ <class 'str'>
<urllib3.response.HTTPResponse object at 0x0000018470426AF0> <class 'urllib3.response.HTTPResponse'>
True <class 'bool'>
False <class 'bool'>
OK <class 'str'>
200 <class 'int'>
'''
  • url:str类型
  • raw:暂时未找到应用方式
  • ok:bool类型,判断是否为200
  • is_redirect:bool类型,判断是否为3xx
  • reason:str类型,状态描述
  • status_code:int类型,状态代码

(4)encoding、apparent_encoding、cookies、history、

print(res.encoding, type(res.encoding))
print(res.apparent_encoding, type(res.apparent_encoding))
print(res.cookies, type(res.cookies))
print(res.history, type(res.history))
'''
ISO-8859-1 <class 'str'>
utf-8 <class 'str'>
<RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]> <class 'requests.cookies.RequestsCookieJar'>
[] <class 'list'>
'''
  • encoding:编码,str类型
  • apparent_encoding:表现编码,str类型
  • cookies:自定义类型,可以通过其对象方法操作
  • history:历史,list类型

(5)content、text、links

print(res.text.encode(encoding=res.encoding).decode(res.apparent_encoding))
print(res.content, type(res.content))
print(res.links, type(res.links))
'''
xxx
b'xxx' <class 'bytes'>
{} <class 'dict'>
'''
  • text:内容部分,str类型。其一般会进行字符编码传输,res.encoding指定传输编码。而apparent_encoding指定重新编码
    • 但注意res.encoding参数可能会为None,该请求会报错,所以需要先做判断
    • apparent_encoding一般直接指定为utf-8
  • context:内容部分,bytes字节类型
  • links:字典类型

(6)elapsed、next、is_permanent_redirect

print(res.elapsed, type(res.elapsed))
print(res.next, type(res.next))
print(res.is_permanent_redirect, type(res.is_permanent_redirect))
'''
0:00:00.230697 <class 'datetime.timedelta'>
None <class 'NoneType'>
False <class 'bool'>
'''
  • elapsed:请求的响应时间
  • next:一般是重定向使用的路径
  • is_permanent_redirect:是否永久重定向

标签:name,url,res,request,模块,print,requests,type
From: https://www.cnblogs.com/wd404/p/17323947.html

相关文章

  • requests模块Request类
    1、介绍requests.request函数执行返回requests.Response类的对象。当然,其他请求函数执行返回也是如此。然后res.request可以调用获取该响应对象的请求对象,即requests.Request类的对象。如果没有重定向,此时的Request即基本是设置request请求函数的参数设置的。2、类和初始化cl......
  • requests模块Response类
    1、介绍requests.request函数执行的返回对象即requests.Response类的对象。当然,其他请求函数执行返回也是如此。2、类和初始化classResponse:__attrs__=["_content","status_code","headers","url","history&qu......
  • 汉源高科1分8口工业级485集线器8路16路中继器分线器485hub信号隔离器模块
    汉源高科1分8口工业级485集线器8路16路中继器分线器485hub信号隔离器模块......
  • Nginx之数据流代理stream模块简介和使用
    转自 http://t.csdn.cn/RV4Hi一、stream模块简介  stream模块一般用于TCP/UDP数据流的代理和负载均衡,通过stream模块我们可以代理转发tcp报文。ngx_stream_core_module模块从1.9.0版开始提供。默认情况下,此模块不是构建的,应该使用–withstream配置参数启用它,即我们需要使用.......
  • burp攻击模块
    1、介绍intruder入侵模块,实际上是基于不同策略的重复请求,然后测试人员可以结合测试参数,分析响应。从其他模块,选择请求,右键选择sendtointruder,可以将其请求提交到intruder模块进行操作。2、攻击类型选择和测试文本标记(1)攻击类型有四种sniper:狙击手模式,使用一个payload集合......
  • abp(net core)+easyui+efcore实现仓储管理系统——模块管理升级之上(六十一)
     Abp(netcore)+easyui+efcore实现仓储管理系统目录abp(netcore)+easyui+efcore实现仓储管理系统——ABP总体介绍(一)abp(netcore)+easyui+efcore实现仓储管理系统——解决方案介绍(二)abp(netcore)+easyui+efcore实现仓储管理系统——领域层创建实体(三) abp(netcore)+e......
  • 七彩RGB可控模块教程
    一、硬件介绍七彩RGB可控模块,是个LED灯。但是它有三种颜色,分别为红、绿、蓝。该模块有四个接口,分别是Gnd、R、G、B。 二、控制原理通过PWM来控制LED灯的亮度,除此之外R、G、B、三个口要接三个不同的GPIO口。其实你也将RGB可控模块理解为三个不同颜色的LED灯。 三、......
  • Python模块-requests
    1、requests模块requests模块是python中原生的基于网络请求的模块,其主要作用是用来模拟浏览器发起请求。功能强大,用法简洁高效。2、模块介绍及请求过程requests模块模拟浏览器发送请求请求流程:指定url-->发起请求-->获取响应对象中存储的数据-->持久化存储3、爬取百度首页#!......
  • Python模块-socket
    1、基于TCP协议的socket通信以打电话为理解方式进行TCP的通信#Server端importsocketphone=socket.socket(socket.AF_INET,socket.SOCK_STREAM)#购买电话卡,AF_INET服务器之间网络通信,socket.SOCK_STREAM,流式协议,就是TCP协议phone.bind(('127.0.0.1',8080))......
  • java——maven——分模块——资源加载属性值
    第一步:   第二步:    第三步:                       ......