我一直在深入研究Python類中的運算符重載和特殊方法,并且我注意到許多內置函數具有等效的特殊方法名稱:
> int(x)調用x .__ int __()
> next(x)在Python 2中調用x .__ next __()或x.next()
但是,一些函數,即tuple()和dict(),沒有任何等價物.我知道對于這種特殊方法尚未出現這種需要,但在某些情況下,調用類的dict()轉換方法可能很有用.我該如何實現呢?或者,對于試圖使用這種邏輯的人,您會怎么說?
# I think this is quite interesting, so I shall post my own implementation of it as well
解決方法:
選項1:__iter__
轉換為元組或字典,或任何采用迭代的類型,都依賴于__iter__方法.
class ListOfKeys():
def __init__(self, lst):
self.lst = lst
def __iter__(self):
for k in self.lst:
yield (k, None)
lok = ListOfKeys([1, 2, 3])
d = dict(lok)
print(d) # {1: None, 2: None, 3: None}
這同樣適用于元組.
t = tuple(lok)
print(t) # ((1, None), (2, None), (3, None))
選項2:鍵和__getitem__
或者,要轉換為dict,您可以實現兩個鍵和__getitem__.
class ListOfKeys():
def __init__(self, lst):
self.lst = lst
def keys(self):
yield from self.lst
def __getitem__(self, item):
return None
lok = ListOfKeys([1, 2, 3])
d = dict(lok)
print(d) # {1: None, 2: None, 3: None}
選項3:兩者都支持多種類型
最后,如果您希望您的類具有不同的行為以轉換為dict和元組,則以下示例演示dict將優先考慮鍵和__getitem__解決方案.
class Foo:
def __iter__(self):
yield 1
def keys(self):
yield 2
def __getitem__(self, item):
return 3
print(dict(Foo())) # {2: 3}
print(tuple(Foo())) # (1,)
標簽:python,python-3-x,class,function,oop
來源: https://codeday.me/bug/20190828/1746542.html