1.__call__方法
在创建好一个实例后,直接调用一个实例会报错。但使用__call__后,可以让这个实例可以像方法一样被调用(就是一个函数后面加个括号的函数调用形式)
class Person:
pass
p1 = Person()
p1() # 实例这样无法直接被调用
使用类和__call__方法
class PenFactory(object):
def __init__(self, p_type):
self.p_type = p_type
def __call__(self, p_color):
print(f"创建了一个{self.p_type}类型的钢笔,它的颜色是{p_color}")
gangbiF = PenFactory("钢笔") #实例化
gangbiF("黄色")
#直接调用实例,实例可以像方法一样被调用调用的是类中的__call__方法
2.索引操作(使对象具有像字典一样的索引操作)
class Person:
def __init__(self):
self.cache = {}
def __setitem__(self, key, value):
# print("setitem", key, value)
self.cache[key] = value
def __getitem__(self, item):
# print("getitem", item)
return self.cache[item]
def __delitem__(self, key):
# print("delitem", key)
del self.cache[key]
p = Person()
p["name"] = "sz"
print(p["name"])
del p["name"]
# print(p["name"])
print(p.cache)
3.遍历操作(使得实例化的对象可以被遍历)
注:一般实现遍历,会用到两种方法:
1. for...in...
2. 使用next迭代 (针对迭代器)
3.1方法一:类中使用__getitem__方法
class Person:
def __init__(self):
self.result = 1
def __getitem__(self, item):
self.result += 1
if self.result >= 6:
raise StopIteration("停止遍历")
return self.result
p = Person()
for i in p:
print(i)
3.2方法二:使用__iter__和__next__方法(比较正宗的方法)
class Person:
def __init__(self):
self.result = 1
def __iter__(self):
print("iter")
return self
def __next__(self):
self.result += 1
if self.result >= 6:
raise StopIteration("停止遍历")
return self.result
p = Person()
for i in p:
print(i)
# print(next(p))
# print(next(p))
# print(next(p))
# print(next(p))
# print(next(p))
# print(next(p))
3.3迭代器的复用
class Person:
def __init__(self):
self.result = 1
def __iter__(self):
print("iter")
# self.result = 1
return self
def __next__(self):
self.result += 1
if self.result >= 6:
raise StopIteration("停止遍历")
return self.result
p = Person()
使用迭代器时,首先会执行__iter__方法,再执行__next__方法,迭代器在迭代完毕后,
会到最后一个元素,是没有办法自动循环从头迭代的。因此下面的循环不能重复执行
在__iter__方法中添加self.result = 1,第二次使用迭代器,先执行__iter__方法,
将self.result置为1,再执行__next__方法,就可以迭代了
for i in p:
print(i)
for i in p:
print(i)