requests模块封装参考

2023年 9月 4日 109.7k 0

一、requests简介

requests是一个常用的HTTP请求库,可以方便地向网站发送HTTP请求,并获取响应结果;
requests模块比 urllib 模块更简洁;使用 requests发送HTTP请求需要先导入requests模块,导入后就可以发送HTTP请求,使用requests提供的方法向指定url发送HTTP请求

关于python开发的HTTP库,在Python内置模块的基础上进行了高度的封装,从而使得Pythoner进行网络请求时,变得美好了许多,使用requests可以完成浏览器任何操作

二、请求类型

HTTP的请求类型有POST、GET、PUT、DELETE、HEAD以及OPTIONS,其中POST和GET是最常使用的

三、使用demo

# 导入requests包  
import requests  
  
# 发送请求  
response = requests.get('https://www.runoob.com/')  
  
# 返回网页内容  
print(response.text)

注意:每次调用requests请求之后,会返回一个response对象,该对象包含了具体的响应信息,如状态码、响应头、响应内容等:

  • response.text:获取文本响应内容,即网页源代码(str格式)
  • response.context:获取二进制响应内容,即网页源代码(bytes格式)
  • response.json():获取JSON响应内容
  • response.raw:获取原始响应内容
  • response.status_code:响应状态码,返回值为200表示网络请求正常
  • response.encoding:编码方式
  • response.apparent_encoding:从内容中分析出的响应内容编码方式
  • response.request:请求对象;主要包括url、method、headers等
  • response.url:输出请求的网址链接
  • print(response.status_code)  # 获取响应状态码
    print(response.headers)  # 获取响应头
    print(response.content)  # 获取响应内容
    

    四、个人风格requests封装

    import retrying # 需手动安装
    
    
    class HTTP(object):
        """
        requests模块封装使用:
        import HTTP
      
        # post调用时格式为json格式
        headers = {
            "Content-Type": "application/json",
            "Charset": "UTF-8"
        }
    
        result = HTTP.get(url, params)
        result = HTTP.post(url, data=json.dumps(payload), headers=header)
        """
        
        @staticmethod
        def __requests(method, url, **kwargs):
            """
            发送http请求
            @param url: 接口url
            @param method: http请求方法
            @param kwargs: 接受request原生的关键字参数
            @return 响应对象
            """
            resp = getattr(requests, method)(url, **kwargs)
            if resp.status_code == 200:
                result = resp.json()
                return result
            raise Exception('fail:{},url:{},method:{}'.format(json.dumps(resp.content),url,method))
    
        @retrying.retry(stop_max_attempt_number=3)
        def get(self, url, params=None, **kwargs):
            return self.__requests('get', url, params=params, **kwargs)
    
        @retrying.retry(stop_max_attempt_number=3)
        def post(self, url, data, **kwargs):
            return self.__requests('post', url, data=data, **kwargs)
    
        @retrying.retry(stop_max_attempt_number=3)
        def put(self, url, data=None, **kwargs):
            return self.__requests('put', url, data=data, **kwargs)
    
        @retrying.retry(stop_max_attempt_number=3)
        def delete(self, url, **kwargs):
            return self.__requests('delete', url, **kwargs)
            
        @retrying.retry(stop_max_attempt_number=3)
        def head(self, url, **kwargs):
            return self.__requests('head', url, **kwargs)
    
        @retrying.retry(stop_max_attempt_number=3)
        def patch(self, url, data=None, **kwargs):
            return self.__requests('patch', url, data=data, **kwargs)
    

    五、实例demo

    (1)GET请求

    在URL中常见?符号,httpbin.org/get?key=val 这种带有?传递关键字参数的方式,requests可以通过params实现

    condition_params = {'k1':'v1', 'k2':'v2', 'k3':None, 'k4':['v4','v5']}  
    r = requets.get('http://httpbin.org/get', params=condition_params)
    

    注意:

  • 字典中键值为None的键不会被拼接添加到url中
  • 多个键值中间用&符号拼接
  • 键值可是列表例如上例中'k4'
  • 执行结果print(r.url) --> httpbin.org/get?k1=v1&k…
  • (2)POST请求

    import requests
    import json
    
    # 指定post请求时的url
    url = 'https://api.github.com/some/endpoint'  
    
    # 需要上传或发送post请求的数据
    payload = {'some': 'data'} 
    
    # 指定请求格式为json格式
    headers = {'content-type': 'application/json'}  
    
    # 发送请求时将字典转换为json格式数据
    res = requests.post(url, data=json.dumps(payload), headers=headers)  
    

    相关文章

    JavaScript2024新功能:Object.groupBy、正则表达式v标志
    PHP trim 函数对多字节字符的使用和限制
    新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
    使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
    为React 19做准备:WordPress 6.6用户指南
    如何删除WordPress中的所有评论

    发布评论