Python enum(枚举)、type()
# 枚举类 Enum
from enum import Enum
Month = Enum('Month',('Jan','Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'))
for name,member in Month.__members__.items():
# value属性则是自动赋给成员的int常量,默认从1开始计数
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
# 如果需要更精确地控制枚举类型,可以从Enum派生出自定义类
from enum import Enum,unique
@unique
class WeekDay(Enum):
Sun = 0 #设置sun 的value为0
Mon = 1
Tue = 2
Wed = 3
Thu = 4
Fri = 5
Sat = 6
# Sat = 6 # 如果重复会报错 TypeError: Attempted to reuse key: 'Sat'
# @unique装饰器可以帮助我们检查保证没有重复值
# 访问这些枚举类型可以有若干种方法:
day1 = WeekDay.Mon
print(day1) # WeekDay.Mon
print(WeekDay.Thu) # WeekDay.Thu
print(WeekDay['Tue']) # WeekDay.Tue
print(WeekDay.Tue.value) # 2
print(day1 == WeekDay.Mon) # True
print(day1 == WeekDay.Sun) # False
print(WeekDay(1)) # WeekDay.Mon
print(day1 == WeekDay(1)) # True
print(Weekday(7)) # NameError: name 'Weekday' is not defined
python type()动态创建类
type()函数可以查看一个类型或变量的类型,Hello是一个class,它的类型就是type,而h是一个实例,它的类型就是class Hello。
我们说class的定义是运行时动态创建的,而创建class的方法就是使用type()函数。
type()函数既可以返回一个对象的类型,又可以创建出新的类型,比如,我们可以通过type()函数创建出Hello类,而无需通过class Hello(object)…的定义:
def fn(self,name='world'):
print('hello,%s.' % name)
Hello = type('Hello',(object,),dict(hello=fn))
h = Hello()
h.hello() # hello world.
h.hello('py') # hello py.
print(type(Hello)) # <class 'type'>
print(type(h)) # <class '__main__.Hello'>
要创建一个class对象,type()函数依次传入3个参数:
class的名称;
继承的父类集合,注意Python支持多重继承,如果只有一个父类,别忘了tuple的单元素写法;
class的方法名称与函数绑定,这里我们把函数fn绑定到方法名hello上。
通过type()函数创建的类和直接写class是完全一样的,因为Python解释器遇到class定义时,仅仅是扫描一下class定义的语法,然后调用type()函数创建出class。
正常情况下,我们都用class Xxx…来定义类,但是,type()函数也允许我们动态创建出类来,也就是说,动态语言本身支持运行期动态创建类,这和静态语言有非常大的不同,要在静态语言运行期创建类,必须构造源代码字符串再调用编译器,或者借助一些工具生成字节码实现,本质上都是动态编译,会非常复杂。