Python中常見的容器類型包括dict、tuple、list和string。其中,tuple和string是不可變容器,dict和list是可變容器。其區別在於,不可變容器一旦賦值后,其元素不能進行修改。
然而,有時針對特殊需求,我們還需要自定義容易。
1、自定義不可變容器類型:需要定義__len__和__getitem__方法;
2、自定義可變容器類型:除需要定義__len__和__getitem__方法外,還需要定義__setitem__和__getitem__方法;
3、自定義的數據類型需要迭代:需要定義__iter__
4、返回自定義容器的長度:需要實現__len__(self)
5、自定義容易可以調用 self[key] , 如果key類型錯誤,拋出 TypeError ,如果無法返回 key 對應的數值時,拋出 ValueError :需要調用的是__getitem__(self, key)這個方法
6、當執行 self[key] = value 時:需要調用的是__setitem__(self, key, value)這個方法
7、當執行 del self[key]時:需要調用的是__delitem__(self, key)這個方法
8、當容器可以執行 for x in container: ,或者使用iter(container)時:需要實現__iter__(self),該方法返回的是一個迭代器
看一個例子,創建一個容器,該容器加強了內置類型list的功能,增加一些方法:
#!/usr/bin/env python3 # -*- coding: UTF-8 -*- class FunctionalList: ''' 實現了內置類型list的功能,並豐富了一些其他方法: head, tail, init, last, drop, take''' def __init__(self, values=None): if values is None: self.values = [] else: self.values = values def __len__(self): return len(self.values) def __getitem__(self, key): return self.values[key] def __setitem__(self, key, value): self.values[key] = value def __delitem__(self, key): del self.values[key] def __iter__(self): return iter(self.values) def __reversed__(self): return FunctionalList(reversed(self.values)) def append(self, value): self.values.append(value) def head(self): # 獲取第一個元素 return self.values[0] def tail(self): # 獲取第一個元素之后的所有元素 return self.values[1:] def init(self): # 獲取最后一個元素之前的所有元素 return self.values[:-1] def last(self): # 獲取最后一個元素 return self.values[-1] def drop(self, n): # 獲取所有元素,除了前N個 return self.values[n:] def take(self, n): # 獲取前N個元素 return self.values[:n] if __name__ == '__main__': l = FunctionalList([1,2,3,4,5,6]) print("length:", len(l)) print("l[2]:", l[2]) l[2] = 33 print("l[2]:", l[2]) print("l.head():", l.head()) print("l.tail():", l.tail()) print("l.last():", l.last()) print("l.drop(3):", l.drop(3)) print("l.take(3):", l.take(3)) ##########執行結果########## C:\Python35\python3.exe D:/Project/Python/Pro_py3/test.py length: 6 l[2]: 3 l[2]: 33 l.head(): 1 l.tail(): [2, 33, 4, 5, 6] l.last(): 6 l.drop(3): [4, 5, 6] l.take(3): [1, 2, 33] Process finished with exit code 0