网站首页样式,百度推广是什么工作,徐州关键词优化公司,盘锦做网站价格(1)背景python中#xff0c;对于类(自定义类)的实例对象的默认显示既没有太大用处#xff0c;也不美观。比如#xff1a;1 classadder:2 def __init__(self,value0):3 self.datavalue #初始化数据4 def __add__(self,other):5 self.dataother6 xadder()7对于类(自定义类)的实例对象的默认显示既没有太大用处也不美观。比如1 classadder:2 def __init__(self,value0):3 self.datavalue #初始化数据4 def __add__(self,other):5 self.dataother6 xadder()7print(x)__main__.adder. object at8x而通过__str__或者__repr__可以定制化(costomise)显示比如下面代码中在子类中定义了一个返回实例字符的__repr__方法。注意在python3中所有对象都继承了object的__str__也就是实例对象的默认显示。1 classaddrepr(adder):2 def __repr__(self):3 return addrepr(%s)%self.data4 xaddrepr(2) #运行__init__5 x1 #运行__add__6 x #运行__repr__7 addrepr(3)8 print(x) #运行__repr__9 addrepr(3)10 str(x),repr(x) #均运行__repr__11 (addrepr(3),addrepr(3))View Code当类实例化对象被打印或者转化为字符时如果定义了__repr__(或者__str__)那么该__repr__(或者__str__)将被自动调用这里__repr__用了最基本的字符格式来将self.data转化为友好的字符显示。(2)为什么要用两种显示方法虽然__str__与__rer__的作用都是为了获得更友好的字符显示但对于代码的设计有一些细微的区别。(a)对于print和str内建函数程序会首先尝试__str__函数如果没有__str__函数则尝试__repr__函数如果没有__repr__函数则选用默认显示(b)在其他情况下比如交互式回应(interactive echoes)repr函数和嵌套中__repr__被调用一般地它应该为开发者返回较为详细的显示。下面通过代码说明两种方法的不同1 classaddstr(adder):2 def __str__(self):3 return [value:%s]%self.data4 xaddstr(3)5 x #默认显示6 __main__.addstr object at7 print(x) #调用__str__8 [value:4]9 str(x),repr(x)10 ([value:4],__main__.addstr object at(c)如果同时定义了两种方法那么可以在不同情况下支持不同的显示。如下面代码1 classaddboth(adder):2 def __str__(self):3 return [value:%s]%self.data4 def __repr__(self):5 return addboth(%s)%self.dat6 xaddboth(4)7 x18 x #调用__repr__9 addboth(5)10 print(x) #调用__str__11 [value:5]12 str(x),repr(x) #分别调用__str_,__repr__13 ([value:5],addboth(5))总结下来以上几点就是只有在print()str()时才会调用__str__()(如果没有__str__则调用__repr__)其他情况均调用__repr__如交互式情况下单独显示repr()等。(3)使用的三点注意(a)首先是__str__和__repr__必须均返回字符返回其他类型将会报错所以必要的话必须确保它们进行字符转换(比如str,%s)。(b)根据容器(container)的字符转换仅有当对象出现在print的顶层时才会调用__str__嵌套在大的对象里的对象显示将仍调用__repr__下面代码说明了这一点1 classPrinter:2 def __init__(self,value)3 self.valuevalue4 def __str__(self):5 returnstr(self.value)6 objs[Printer(2),Printer(3)]7 for x in objs:print(x)89 210 311 print(objs)12 [__main__.printer object at]13 objs14 [__main__.printer object at__main__.printer object at]为确保不论有无容器在所有情况下显示设定的显示模式用__repr__,不用__str__用如下代码进行说明1 classPrinter:2 def __init__(self,value):3 self.valvalue4 def __repr__(self): #如果没有__str__调用__repr__5 return %s%self.val678 objs[Printer(2),Printer(3)]9 for x in objs:print(x)1011 212 313 print(objs) #调用__repr__14 [2, 3]15 objs16 [2, 3](c)第三也是最为微妙的显示方法在极少情况下有时又也有可能触发无限迭代循环(infinite recursion loops)因为一些对象的显示包括了其他对象的的显示而一个显示触发了正在被显示的对象的显示因而进入无限循环中。如下代码this scripts is intended to illustrate the infinite recursion loopscaused by __repr__ overloading methods. displaying the value of a method,line10 in this script, can trigger the __repr__of the class method, then the __repr__ method is called again, and the infinite recursion loops happen.classBase:def __init__(self):self.data1defprint0(self):passdefprint1(self):astr(getattr(self,print0)) #Caution! getattr(object,attrname),attrname shall be string.returnaclassNormal(Base):def __str__(self):return %s%self.print1()classRecursion(Base):def __repr__(self):return %s%self.print1()if __name____main__:aNormal()bRecursion()print(a)try:print(b)exceptRecursionError:print(A recusion error happens)运行结果为A recusion error happens