Python enum模块提供类型安全、可迭代、不可变的命名常量枚举类,支持名称/值双向查找、auto()自动赋值、@unique防别名、属性方法扩展及IntEnum整数比较。
Python 的 enum 模块提供了一种清晰、安全、可读性强的方式来定义一组命名常量。它不是简单地用变量代替数字,而是构建出有类型、可迭代、不可变、支持名称/值双向查找的枚举类。
从 enum 导入 Enum,继承后定义类成员即可:
.name)和值(.value)组成,二者严格分离Color.RED 返回枚举成员对象Color.RED.name → "RED"
Color.RED.value → 1
Color["RED"] 等价于 Color.RED
Color(1) 返回 Color.RED(自动映射,不创建新实例)枚举类本身可直接迭代,返回的是规范成员(排除别名),顺序按定义顺序:
for color in Color: print(color.name, color.value)
列表:获取所有成员对象组成的列表list(Color) → [, , ...]
[c.name for c in Color] 或 [c.value for c in Color]
避免手动编号重复,可用 auto() 自动生成递增整数:
from enum import Enum, autoclass Status(Enum): PENDING = auto(); PAID = auto() → 值分别为 1、2BLUE = 1 和 YELLOW = 1),BLUE is YELLOW 为 True
@unique 装饰器,重复值会触发 ValueError
枚举成员可以携带额外数据,并封装逻辑:
__init__ 中接收构造参数,绑定实例属性@property 定义只读计算属性(如行星质量、半径推导重力加速度)__str__ 或 __repr__ 提升可读性IntEnum 继承不复杂但容易忽略:枚举类不能被实例化,成员不可修改,也不支持大小比较(>、 会报 TypeError),仅支持身份(is)和相等(==)判断。