Enum 是个类
所以
根本的类操作都能够用
也就是咱们能够增加本人的办法
class Mood(Enum): FUNKY = 1 HAPPY = 3 def describe(self): # self is the member here return self.name, self.value def __str__(self): return 'my custom str! {0}'.format(self.value) @classmethod def favorite_mood(cls): # cls here is the enumeration return cls.HAPPY
>>> Mood.favorite_mood()<Mood.HAPPY: 3>>>> Mood.HAPPY.describe()('HAPPY', 3)>>> str(Mood.FUNKY)'my custom str! 1'
Enum的每个类成员,都会主动被转换成以后类的一个实例
from enum import Enumclass Color(Enum): RED = 1 GREEN = 2 BLUE = 3
>>> type(Color.RED)<enum 'Color'>>>> isinstance(Color.GREEN, Color)True
这就意味着,咱们不能用枚举成员间接当成它的value来用:
>>> Color.RED == 1False>>> Color.RED.value == 1False
枚举成员还有个name属性,跟它的变量名雷同
>>> Color.RED.name == "RED"True
枚举类有个大坑:父类有成员的时候,就不能定义子类
所以,对于下面的Color类,如果还想定义一个子类,就会出错:
>>> class MoreColor(Color):... PINK = 17...Traceback (most recent call last):...TypeError: MoreColor: cannot extend enumeration 'Color'
但父类没有枚举成员,仅仅定义了函数是能够的:
class Foo(Enum): def some_behavior(self): passclass Bar(Foo): HAPPY = 1 SAD = 2
这显然大大限度了枚举类的扩大,一个不能拜访成员的函数,用途也就不大了。