关于python中Enum的个人总结

  1. 初识

    1. 可以通过enum模块导入
  2. 语法

    1. 初始化:

      • 可以通过enum_ = Enum('class_name', names,start = 1)来创建,其中names可以是字符串,可以是列表/元组。内部定义为:
       def _create_(cls, class_name, names, *, module=None, qualname=None, type=None, start=1):
      """Convenience method to create a new Enum class. `names` can be: * A string containing member names, separated either with spaces or
      commas. Values are incremented by 1 from `start`.
      * An iterable of member names. Values are incremented by 1 from `start`.
      * An iterable of (member name, value) pairs.
      * A mapping of member name -> value pairs. """
      metacls = cls.__class__
      bases = (cls, ) if type is None else (type, cls)
      _, first_enum = cls._get_mixins_(bases)
      classdict = metacls.__prepare__(class_name, bases) # special processing needed for names?
      if isinstance(names, str):
      names = names.replace(',', ' ').split()
      if isinstance(names, (tuple, list)) and names and isinstance(names[0], str):
      original_names, names = names, []
      last_values = []
      for count, name in enumerate(original_names):
      value = first_enum._generate_next_value_(name, start, count, last_values[:])
      last_values.append(value)
      names.append((name, value)) # Here, names is either an iterable of (name, value) or a mapping.
      for item in names:
      if isinstance(item, str):
      member_name, member_value = item, names[item]
      else:
      member_name, member_value = item
      classdict[member_name] = member_value
      enum_class = metacls.__new__(metacls, class_name, bases, classdict) # TODO: replace the frame hack if a blessed way to know the calling
      # module is ever developed
      if module is None:
      try:
      module = sys._getframe(2).f_globals['__name__']
      except (AttributeError, ValueError, KeyError) as exc:
      pass
      if module is None:
      _make_class_unpicklable(enum_class)
      else:
      enum_class.__module__ = module
      if qualname is not None:
      enum_class.__qualname__ = qualname return enum_class

      通过这样就可以初始化并返回一个枚举类。

      1. 关于Enum的元素的使用

        • 通过源码可知:可以通过:enum_(value).vlaue/name,或者sth = enum.name-->sth.name/value,至于为什么,需要查看源码:

        • class DynamicClassAttribute:
          """Route attribute access on a class to __getattr__. This is a descriptor, used to define attributes that act differently when
          accessed through an instance and through a class. Instance access remains
          normal, but access to an attribute through a class will be routed to the
          class's __getattr__ method; this is done by raising AttributeError. This allows one to have properties active on an instance, and have virtual
          attributes on the class with the same name (see Enum for an example). """
          def __init__(self, fget=None, fset=None, fdel=None, doc=None):
          self.fget = fget
          self.fset = fset
          self.fdel = fdel
          # next two lines make DynamicClassAttribute act the same as property
          self.__doc__ = doc or fget.__doc__
          self.overwrite_doc = doc is None
          # support for abstract methods
          self.__isabstractmethod__ = bool(getattr(fget, '__isabstractmethod__', False)) def __get__(self, instance, ownerclass=None):
          if instance is None:
          if self.__isabstractmethod__:
          return self
          raise AttributeError()
          elif self.fget is None:
          raise AttributeError("unreadable attribute")
          return self.fget(instance) def __set__(self, instance, value):
          if self.fset is None:
          raise AttributeError("can't set attribute")
          self.fset(instance, value) def __delete__(self, instance):
          if self.fdel is None:
          raise AttributeError("can't delete attribute")
          self.fdel(instance) def getter(self, fget):
          fdoc = fget.__doc__ if self.overwrite_doc else None
          result = type(self)(fget, self.fset, self.fdel, fdoc or self.__doc__)
          result.overwrite_doc = self.overwrite_doc
          return result def setter(self, fset):
          result = type(self)(self.fget, fset, self.fdel, self.__doc__)
          result.overwrite_doc = self.overwrite_doc
          return result def deleter(self, fdel):
          result = type(self)(self.fget, self.fset, fdel, self.__doc__)
          result.overwrite_doc = self.overwrite_doc
          return result

          需要先实例化才能使用。

  3. 结语

    最后,Enum不仅可以是一个好的枚举也可以拿来代替一些繁琐的类、状态、顺序等东西。比如说:`life = Enum('life', 'born baby teenager adult older die')。

    当然,更多的秘密等着你们自己去挖掘。

关于python中Enum的个人总结的更多相关文章

  1. Python中模拟enum枚举类型的5种方法分享

    这篇文章主要介绍了Python中模拟enum枚举类型的5种方法分享,本文直接给出实现代码,需要的朋友可以参考下   以下几种方法来模拟enum:(感觉方法一简单实用) 复制代码代码如下: # way1 ...

  2. Python 中的枚举类型~转

    Python 中的枚举类型 摘要: 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表示某些特定的有限集合,例如星期.月份.状态等. 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表 ...

  3. Python中的枚举

    在Python中想要实现枚举功能的方式比较多,可以通过字典这一数据结构,利用键与值的对应关系,可以实现枚举的功能. my_Enum={ 'red':1, 'yellow':2, 'blue':3 } ...

  4. Python中使用枚举类

    开发中我们经常定义常量, 其实有更好的方法:为这样的枚举类型定义一个class类型,然后,每个常量都是class的一个唯一实例.Python中提供了Enum类来实现这个功能: from enum im ...

  5. python 枚举Enum

    常量是任何一门语言中都会使用的一种变量类型 如 要表示星期常量,我们可能会直接定义一组变量 JAN = 1 TWO = 2 ... 然后在返回给前端的时候,我们返回的就会是1,2,...这种魔法数字, ...

  6. 数据库MySql在python中的使用

    随着需要存储数据的结构不断复杂化,使用数据库来存储数据是一个必须面临的问题.那么应该如何在python中使用数据库?下面就在本篇博客中介绍一下在python中使用mysql. 首先,本博客已经假定阅读 ...

  7. Python IAQ中文版 - Python中少有人回答的问题

    Python中少有人回答的问题 The Python IAQ: Infrequently Answered Questions 1 Q: 什么是"少有人回答的问题(Infrequently ...

  8. Json schema 以及在python中的jsonschema

    目录 1. JSON Schema简介 2. JSON Schema关键字详解 2.1 $schema 2.2 title和description 2.3 type 3 type常见取值 3.1 当t ...

  9. sqlalchemy python中的mysql数据库神器

    在介绍sqlalchemy之前,我们先了解一下ORM. ORM 全称 Object Relational Mapping, 翻译过来叫对象关系映射.也就是说ORM 将数据库中的表与面向对象语言中的类建 ...

随机推荐

  1. 题解 CF1359B 【New Theatre Square】

    题意 有一个 n×m 的广场,其中一部分要铺地砖,地砖有两种, 1 × 1 和 1×2 的,后者只能横着铺,其中, 1 × 1的单价为 x , 1 × 2 的单价为 y , 输入这个广场," ...

  2. Spring事务源码分析专题(一)JdbcTemplate使用及源码分析

    Spring中的数据访问,JdbcTemplate使用及源码分析 前言 本系列文章为事务专栏分析文章,整个事务分析专题将按下面这张图完成 对源码分析前,我希望先介绍一下Spring中数据访问的相关内容 ...

  3. Monster Audio 使用教程 (七) 防止声音过大,出现爆音

    有用户反映,如果音乐音量过大,会出现爆音. 这其实是音频信号过载了.只要最后输出的音量超过0db,就会出现爆音,这是数字音频都应该注意的问题. 所以,为了解决这个问题,限制器就出现了,它能把音频信号压 ...

  4. 推荐一款技术人必备的接口测试神器:Apifox

    1. 背景 作为互联网行业技术从业者,接口调试是必不可少的一项技能,通常我们都会选择使用 Postman 这类工具来进行接口调试,在接口调试方面 Postman 做的确实非常出色.当然除了Postma ...

  5. BUUCTF-web HappyCTFd (CVE-2020-7245)

    在 CTFd v2.0.0 - v2.2.2 的注册过程中,如果在CTFd的用户名和emails可用,则可以使攻击者接管任意账号. 进入题目,进行注册.查看用户可以看到admin账号,利用漏洞获取ad ...

  6. 在java中进行日期时间比较的4种方法

    1. Date.compareTo() java.util.Date提供了在Java中比较两个日期的经典方法compareTo(). 如果两个日期相等,则返回值为0. 如果Date在date参数之后, ...

  7. vector 赋初始值的问题

    这个,输出为1 这个,啥都输不出来. 据说是因为没有初始化. 其实我搜了一下 vector<vector<int> > A;//正确的定义方式 vector<vector ...

  8. 哇咔咔干货来啦:PowerJob 原理剖析之 Akka Toolkit

    本文适合有 Java 基础知识的人群 作者:HelloGitHub-Salieri HelloGitHub 推出的<讲解开源项目>系列. Akka is a toolkit for bui ...

  9. 360随身WiFi3:纯净版无线网卡驱动下载及安装教程(Windows10版本)

    对于不带无线网卡的台式机,买一个360随身WiFi当无线网卡是很省钱的方法.但是这个随身WiFi3用的芯片较为奇葩,Win10下不太好找驱动.什么,你问我为啥不用360官网上的驱动?那个“驱动”装了之 ...

  10. 学习python的几个资料网站

    菜鸟教程 https://www.runoob.com/python3/python3-tutorial.html https://www.runoob.com/python/python-tutor ...