A. python的枚舉實現中`type,enums`是什麼意思
type 這種三個參數的調用,其結果是返回一個「類」,就跟用 class 定義是一樣的。
所以, type('Enum', (), {'ONE': 1, 'TWO': 2}) 就相當於:
class Enum(object):
ONE = 1
TWO = 2
B. python 枚舉類型什麼意思
枚舉類型可以看作是一種標簽或是一系列常量的集合,通常用於表示某些特定的有限集合,例如星期、月份、狀態等。Python 的原生類型(Built-in types)里並沒有專門的枚舉類型,但是我們可以通過很多方法來實現它,例如字典、類等:
WEEKDAY = {
'MON': 1,
'TUS': 2,
'WEN': 3,
'THU': 4,
'FRI': 5
}
class Color:
RED = 0
GREEN = 1
BLUE = 2
上面兩種方法可以看做是簡單的枚舉類型的實現,如果只在局部范圍內用到了這樣的枚舉變數是沒有問題的,但問題在於它們都是可變的(mutable),也就是說可以在其它地方被修改從而影響其正常使用:
WEEKDAY['MON'] = WEEKDAY['FRI']
print(WEEKDAY)
{'FRI': 5, 'TUS': 2, 'MON': 5, 'WEN': 3, 'THU': 4}
通過類定義的枚舉甚至可以實例化,變得不倫不類:
c = Color()
print(c.RED)
Color.RED = 2
print(c.RED)
0
2
當然也可以使用不可變類型(immutable),例如元組,但是這樣就失去了枚舉類型的本意,將標簽退化為無意義的變數:
COLOR = ('R', 'G', 'B')
print(COLOR[0], COLOR[1], COLOR[2])
R G B
為了提供更好的解決方案,Python 通過 PEP 435 在 3.4 版本中添加了 enum 標准庫,3.4 之前的版本也可以通過 pip install enum 下載兼容支持的庫。enum 提供了 Enum/IntEnum/unique 三個工具,用法也非常簡單,可以通過繼承 Enum/IntEnum 定義枚舉類型,其中 IntEnum 限定枚舉成員必須為(或可以轉化為)整數類型,而 unique 方法可以作為修飾器限定枚舉成員的值不可重復:
from enum import Enum, IntEnum, uniquetry:
@unique
class WEEKDAY(Enum):
MON = 1
TUS = 2
WEN = 3
THU = 4
FRI = 1
except ValueError as e:
print(e)
plicate values found in : FRI -> MON
try:
class Color(IntEnum):
RED = 0
GREEN = 1
BLUE = 'b'
except ValueError as e:
print(e)
invalid literal for int() with base 10: 'b'
C. python 怎麼通過枚舉的值
從C系語言過來用Python,好不容易適應了寫代碼不打花括弧,突然有一天發現它居然木有枚舉……於是stackoverflow了一把,發現神人的枚舉(enum)實現到處都是,於是漢化總結過來。
如果是新版Python用戶(Python 3.4 with PEP 435):
from enum import Enum
Animal = Enum('Animal', 'ant bee cat dog')
or
class Animals(Enum):
ant = 1
bee = 2
cat = 3
dog = 4
舊版Python用戶可以充分發揮動態語言的優越性來構造枚舉,有簡單的:
def enum(**enums):
return type('Enum', (), enums)
Numbers = enum(ONE=1, TWO=2, THREE='three')
# Numbers.ONE == 1, Numbers.TWO == 2 and Numbers.THREE == 'three'
有復雜的:
def enum(*sequential, **named):
enums = dict(zip(sequential, range(len(sequential))), **named)
return type('Enum', (), enums)
Numbers = enum('ZERO', 'ONE', 'TWO')
# Numbers.ZERO == 0 and Numbers.ONE == 1
有帶值到名稱映射的:
def enum(*sequential, **named):
enums = dict(zip(sequential, range(len(sequential))), **named)
reverse = dict((value, key) for key, value in enums.iteritems())
enums['reverse_mapping'] = reverse
return type('Enum', (), enums)
# Numbers.reverse_mapping['three'] == 'THREE'
有用set實現的:
class Enum(set):
def __getattr__(self, name):
if name in self:
return name
raise AttributeError
Animals = Enum(["DOG", "CAT", "HORSE"])
print Animals.DOG
有用range實現的:
dog, cat, rabbit = range(3)
# or
class Stationary:
(Pen, Pencil, Eraser) = range(0, 3)
print Stationary.Pen有用tuple實現的:
class Enum(tuple): __getattr__ = tuple.index
State = Enum(['Unclaimed', 'Claimed'])
print State.Claimed
有用namedtuple實現的:
from collections import namedtuple
def enum(*keys):
return namedtuple('Enum', keys)(*keys)
MyEnum = enum('FOO', 'BAR', 'BAZ')
# 帶字元數字映射的,像C/C++
def enum(*keys):
return namedtuple('Enum', keys)(*range(len(keys)))
# 帶字典映射的,可以映射出各種類型,不局限於數字
def enum(**kwargs):
return namedtuple('Enum', kwargs.keys())(*kwargs.values())
D. 命名參數可以與Python枚舉一起使用嗎
雖然不能像枚舉那樣使用命名參數,但是可以通過namedtuple混音:
from collections import namedtuple
from enum import Enum
Body = namedtuple("Body", ["mass", "radius"])
class Planet(Body, Enum):
MERCURY = Body(mass=3.303e+23, radius=2.4397e6)
VENUS = Body(mass=4.869e+24, radius=6.0518e6)
EARTH = Body(mass=5.976e+24, radius=3.3972e6)
# ... etc.
你不必寫一個__init__方法。
示例使用:
>>> Planet.MERCURY
<Planet.MERCURY: Body(mass=3.303e+23, radius=2439700.0)>
>>> Planet.EARTH.mass
5.976e+24
>>> Planet.VENUS.radius
6051800.0
E. 請教Python中枚舉線程的問題
python提供了兩個模塊來實現多線程thread 和threading ,thread 有一些缺點,在threading 得到了彌補,為了不浪費你和時間,所以我們直接學習threading 就可以了。
F. 關於python 函數嵌套
因為最後的那句return nested。
tester()()會自動調用它的返回值,而此時的返回值為nested,即def nested()這個函數,所以自然而然執行到了裡面的print語句。
你可以試試把最後那就return nested改成其他的如return nestedxxx,再tester()()時就會報錯了。
另外,在python里對於方法ester和nested是沒有tester().nested()這種用法的,所以這樣輸入肯定報錯的,如果ester和nested是類(class)的話才有這種寫法。
希望對你有所幫助~~
G. python有沒有類似枚舉類型的
Python 3.4新增了enum模塊。
如果不是Python 3.4,可以看看pypi上的enum34模塊,好像和3.4的enum模塊一樣。
H. python列表的嵌套該怎麽理解
這個List Comprehension相當於一個嵌套循環,外層循環變數是i,內層循環變數是row。
把列表的外層循環改為普通for循環的話,等價於:
temp_list = []
for i in range(4):
temp_list.append([row[i] for row in matrix])
把列表的兩層循環都改為普通for循環寫法,大致相當於:
temp_list = []
for i in range(4):
temp_list.append([])
for row in matrix:
temp_list[-1].append(row[i])
I. 關於Python列表嵌套問題
這個叫元組的拆包或解包。
list1迭代返回的是元組,那麼for循環內就是
m,n = ('c',1)
m,n = ('Python',2)
...
J. 請教python列表嵌套問題
可以這樣寫:
l=[{'name':'張三','性別':'男','年齡':12,'成績':60},{'name':'張三','性別':'女','年齡':12,'成績':80},{'name':'李四','性別':'男','年齡':13,'成績':75},{'name':'王五','性別':'男','年齡':12,'成績':20}]
l=list(filter(lambda d:d['name']=='張三',l))
print(l)
這是運行截圖: