Возможный дубликат:
Как я могу представить "перечисление" в Python?
Какая распространенная практика для перечислений в Python? То есть как они реплицируются в Python?
public enum Materials
{
Shaded,
Shiny,
Transparent,
Matte
}
Возможный дубликат:
Как я могу представить "перечисление" в Python?
Какая распространенная практика для перечислений в Python? То есть как они реплицируются в Python?
public enum Materials
{
Shaded,
Shiny,
Transparent,
Matte
}
class Materials:
Shaded, Shiny, Transparent, Matte = range(4)
>>> print Materials.Matte
3
Я видел этот шаблон несколько раз:
>>> class Enumeration(object):
def __init__(self, names): # or *names, with no .split()
for number, name in enumerate(names.split()):
setattr(self, name, number)
>>> foo = Enumeration("bar baz quux")
>>> foo.quux
2
Вы также можете просто использовать членов класса, хотя вам придется указать свою нумерацию:
>>> class Foo(object):
bar = 0
baz = 1
quux = 2
>>> Foo.quux
2
Если вы ищете что-то более надежное (разреженные значения, исключение для перечисления и т.д.), попробуйте этот рецепт.
Я понятия не имею, почему Enums не поддерживают Python. Лучший способ, которым я нашел, чтобы имитировать их, - это переопределить _ str _ и _ eq _, чтобы вы могли их сравнить, а когда вы используете print(), вы получаете строку вместо численного значения.
class enumSeason():
Spring = 0
Summer = 1
Fall = 2
Winter = 3
def __init__(self, Type):
self.value = Type
def __str__(self):
if self.value == enumSeason.Spring:
return 'Spring'
if self.value == enumSeason.Summer:
return 'Summer'
if self.value == enumSeason.Fall:
return 'Fall'
if self.value == enumSeason.Winter:
return 'Winter'
def __eq__(self,y):
return self.value==y.value
Использование:
>>> s = enumSeason(enumSeason.Spring)
>>> print(s)
Spring
Возможно, вы могли бы использовать структуру наследования, хотя чем больше я играл с этим, тем грязнее я чувствовал.
class AnimalEnum:
@classmethod
def verify(cls, other):
return issubclass(other.__class__, cls)
class Dog(AnimalEnum):
pass
def do_something(thing_that_should_be_an_enum):
if not AnimalEnum.verify(thing_that_should_be_an_enum):
raise OhGodWhy