灵活运用Python 枚举类来实现设计状态码信息

作者:忆想不到的晖 时间:2023-04-29 15:03:34 

引言

web 项目中,我们经常使用自定义状态码来告知请求方请求结果以及请求状态;在 Python 中该如何设计自定义的状态码信息呢?

普通类加字典设计状态码


#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Author: Hui
# @Desc: { 项目响应码模块 }
# @Date: 2021/09/22 23:37

class RETCODE:
   OK                  = "0"
   ERROR               = "-1"
   IMAGECODEERR        = "4001"
   THROTTLINGERR       = "4002"
   NECESSARYPARAMERR   = "4003"

err_msg = {
   RETCODE.OK                 : "成功",
   RETCODE.IMAGECODEERR       : "图形验证码错误",
   RETCODE.THROTTLINGERR      : "访问过于频繁",
   RETCODE.NECESSARYPARAMERR  : "缺少必传参数",
}

单独利用一个字典进行状态码信息对照,这样设计一旦状态码多了就不好对照,再使用过程中也没那么方便,简单试下组织一个成功的信息


data = {
   'code': RETCODE.OK,
   'errmsg': err_msg[RETCODE.OK]
}

巧用枚举类设计状态码信息

利用枚举类就可以巧妙的设计状态码信息

枚举类的定义


#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Author: Hui
# @Desc: { 项目枚举类模块 }
# @Date: 2021/09/23 23:37

from enum import Enum

class StatusCodeEnum(Enum):
   """状态码枚举类"""

OK = (0, '成功')
   ERROR = (-1, '错误')
   SERVER_ERR = (500, '服务器异常')

普通的类继承 enum 模块中的 Enum 类就变成了枚举类。

枚举类的使用

ipython 中测试使用下


In [21]: ok = StatusCodeEnum.OK

In [22]: type(ok)
Out[22]: <enum 'StatusCodeEnum'>

In [23]: error = StatusCodeEnum.ERROR

In [24]: type(error)
Out[24]: <enum 'StatusCodeEnum'>

In [26]: ok.name
Out[26]: 'OK'

In [27]: ok.value
Out[27]: (0, '成功')

In [28]: error.name
Out[28]: 'ERROR'

In [29]: error.value
Out[29]: (-1, '错误')

枚举类中的每一个属性都返回一个枚举对象,其中枚举对象有两个重要的属性 name, value

  • name 枚举对象在枚举类中的属性名

  • value 则是枚举对象在枚举类中对应属性名的值


# StatusCodeEnum.OK ->
#    name     value
#'OK'   (200, '成功')

# StatusCodeEnum.ERROR ->
#    name       value
#'ERROR'   (-1, '错误')

用枚举类组组织一个成功的响应信息


code = StatusCodeEnum.OK.value[0]
errmsg = StatusCodeEnum.OK.value[1]
data = {
   'code': code,
   'errmsg': errmsg
}

咋一看虽然状态码信息一一对照了,也很简洁,但使用起来还是有点麻烦,还有一点就是

StatusCodeEnum.OK.value[0] 这样的语法不能立马见名知义。因此还需对枚举类进行封装

封装枚举类


#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Author: Hui
# @Desc: { 项目枚举类模块 }
# @Date: 2021/09/23 23:37

from enum import Enum

class StatusCodeEnum(Enum):
   """状态码枚举类"""

OK = (0, '成功')
   ERROR = (-1, '错误')
   SERVER_ERR = (500, '服务器异常')

@property
   def code(self):
       """获取状态码"""
       return self.value[0]

@property
   def errmsg(self):
       """获取状态码信息"""
       return self.value[1]

通过 @property 装饰器把类型的方法当属性使用,由于 枚举类.属性名 对应着不同的枚举对象就很好的把状态码和信息进行了封装。看看外部调用的结果


In [32]: StatusCodeEnum.OK.code
Out[32]: 0

In [33]: StatusCodeEnum.OK.errmsg
Out[33]: '成功'

In [34]: StatusCodeEnum.ERROR.code
Out[34]: -1

In [35]: StatusCodeEnum.ERROR.errmsg
Out[35]: '错误'

具体 @property 装饰器的使用详解,可以移步到 Python中property的使用技巧

继续模拟组织响应数据


data = {
   'code': StatusCodeEnum.OK.code,
   'errmsg': StatusCodeEnum.OK.errmsg
}

这下终于可以接受了。

状态码信息枚举类

分享一波我平时用的状态码信息枚举类,供大家参考参考。


#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Author: Hui
# @Desc: { 项目枚举类模块 }
# @Date: 2021/09/23 23:37

from enum import Enum

class StatusCodeEnum(Enum):
   """状态码枚举类"""

OK = (0, '成功')
   ERROR = (-1, '错误')
   SERVER_ERR = (500, '服务器异常')

IMAGE_CODE_ERR = (4001, '图形验证码错误')
   THROTTLING_ERR = (4002, '访问过于频繁')
   NECESSARY_PARAM_ERR = (4003, '缺少必传参数')
   USER_ERR = (4004, '用户名错误')
   PWD_ERR = (4005, '密码错误')
   CPWD_ERR = (4006, '密码不一致')
   MOBILE_ERR = (4007, '手机号错误')
   SMS_CODE_ERR = (4008, '短信验证码有误')
   ALLOW_ERR = (4009, '未勾选协议')
   SESSION_ERR = (4010, '用户未登录')

DB_ERR = (5000, '数据错误')
   EMAIL_ERR = (5001, '邮箱错误')
   TEL_ERR = (5002, '固定电话错误')
   NODATA_ERR = (5003, '无数据')
   NEW_PWD_ERR = (5004, '新密码错误')
   OPENID_ERR = (5005, '无效的openid')
   PARAM_ERR = (5006, '参数错误')
   STOCK_ERR = (5007, '库存不足')

@property
   def code(self):
       """获取状态码"""
       return self.value[0]

@property
   def errmsg(self):
       """获取状态码信息"""
       return self.value[1]

尾语

✍ 用 Code 谱写世界,让生活更有趣。❤️

✍ 万水千山总是情,点赞再走行不行。❤️

✍ 码字不易,还望各位大侠多多支持。❤️

来源:https://blog.csdn.net/qq_43629857/article/details/120456242

标签:Python,枚举类,状态码信息
0
投稿

猜你喜欢

  • 如何利用Python开发一个简单的猜数字游戏

    2022-05-21 20:38:08
  • Blender Python编程实现批量导入网格并保存渲染图像

    2021-06-09 04:21:20
  • 如何利用Python和matplotlib更改纵横坐标刻度颜色

    2022-06-02 04:00:03
  • Numpy实现卷积神经网络(CNN)的示例

    2022-10-06 17:44:17
  • JS中的算法与数据结构之集合(Set)实例详解

    2024-04-16 09:28:34
  • 一文搞懂python 中的迭代器和生成器

    2022-02-11 15:47:14
  • python实现用户名密码校验

    2022-12-14 07:48:33
  • Python使用requests xpath 并开启多线程爬取西刺代理ip实例

    2023-05-01 23:36:51
  • 可输入的select代码

    2009-12-26 18:25:00
  • Perl中的10个操作日期和时间的CPAN模块介绍

    2023-07-27 10:04:41
  • AJAX实现延时顺序请求多个URL

    2007-12-06 18:32:00
  • VS2013连接MySQL5.6成功案例一枚

    2024-01-20 17:36:51
  • Pandas 如何处理DataFrame中的inf值

    2021-03-12 14:03:56
  • 对numpy数据写入文件的方法讲解

    2022-01-24 21:09:31
  • python中input()的用法及扩展

    2021-07-05 08:45:57
  • Python3使用requests发闪存的方法

    2021-06-09 16:07:20
  • 关于ASP代码的加密

    2007-10-15 12:30:00
  • ant design vue datepicker日期选择器中文化操作

    2024-05-09 10:51:35
  • python实现多线程的两种方式

    2022-09-30 00:54:15
  • 利用Python第三方库xlrd读取Excel中数据实例代码

    2023-02-17 05:28:58
  • asp之家 网络编程 m.aspxhome.com