Python 3の使用列挙クラス

2743 ワード

定数を定義する必要がある場合、1つの方法は、月などの大文字変数を整数で定義することです.
JAN = 1
FEB = 2
MAR = 3
APR=4
May=5
Jun=6
Jul=7
Aug=8
Sep=9
Oct=10
NOV = 11
DEC = 12

利点は簡単で、欠点はタイプintであり、変数である.
より良い方法は、このような列挙タイプのclassタイプを定義し、各定数がclassの唯一のインスタンスであることです.Pythonはこの機能を実現するためにEnumクラスを提供しています.
from enum import Enum
Month=Enum('Month', ('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'))

これにより、Monthタイプの列挙クラスが得られ、直接Monthを使用することができる.Janは定数を参照したり、すべてのメンバーを列挙したりします.
>>> Month.Jan

>>> Month.Feb


  
>>> for name,member in Month.__members__.items():
...   print(name,'=>',member,',',member.value)
... 
Jan => Month.Jan , 1
Feb => Month.Feb , 2
Mar => Month.Mar , 3
Apr => Month.Apr , 4
May => Month.May , 5
Jun => Month.Jun , 6
Jul => Month.Jul , 7
Aug => Month.Aug , 8
Sep => Month.Sep , 9
Oct => Month.Oct , 10
Nov => Month.Nov , 11
Dec => Month.Dec , 12

valueプロパティは、メンバーに自動的に付与されるint定数で、デフォルトでは1からカウントされます.
列挙タイプをより正確に制御する必要がある場合は、Enumからカスタムクラスを派生できます.
from enum import Enum,unique
@unique
class Weekday(Enum):
    Sun=0
    Mon=1
    Tue=2
    Wed=3
    Thu=4
    Fri=5
    Sat=6

アクセサリーuniqueは重複しないことを保証します
これらの列挙値にアクセスするには、いくつかの方法があります.
>>> day1 = Weekday.Mon
>>> print(day1)
Weekday.Mon
>>> print(Weekday.Tue)
Weekday.Tue
>>> print(Weekday['Tue'])
Weekday.Tue
>>> print(Weekday.Tue.value)
2
>>> print(day1 == Weekday.Mon)
True
>>> print(day1 == Weekday.Tue)
False
>>> print(Weekday(1))
Weekday.Mon
>>> print(day1 == Weekday(1))
True
>>> Weekday(7)
Traceback (most recent call last):
  ...
ValueError: 7 is not a valid Weekday
>>> for name, member in Weekday.__members__.items():
...     print(name, '=>', member)
...
Sun => Weekday.Sun
Mon => Weekday.Mon
Tue => Weekday.Tue
Wed => Weekday.Wed
Thu => Weekday.Thu
Fri => Weekday.Fri
Sat => Weekday.Sat

メンバー名で列挙定数を参照したり、valueの値に直接基づいて列挙定数を取得したりすることができます.
練習する
Studioのgenderプロパティを列挙タイプに変更すると、文字列の使用を避けることができます.
from enum import Enum, unique
class Gender(Enum):
  Male=0
  Female=1
class Student(object):
    def __init__(self, name, gender):
        self.name = name
        self.gender = gender

bart=Student('Bart',Gender.Male)

  
転載先:https://www.cnblogs.com/minseo/p/11118513.html