直白来说,str、repr以及反引号操作符(‘’)的作用是可以方便地以字符串的形式获取对象的内容、类型和数值属性等信息。在不使用他们的情况下效果是这样滴:
class Test():
def __init__(self,value='Hello World'):
self.value = vlaue
>>> t=Test()
>>> t
<__main__.Test instance at 0x7ff677b47128>
>>> print t
<__main__.Test instance at 0x7ff677b47128>
上边打印出来的类对象为对象的内存地址,对大多数使用者来说并不算友好,因此就有了str和repr的出现,效果如下:
#对上边定义的类进行继承,并重构__repr__
class TestRepr(Test):
def __repr__(self):
return 'TestRepr(%r)'%(self.data)
>>> tr=TestRepr()
>>> tr
TestRepr('hello world!')
>>> print tr
TestRepr('hello world!')
#对上边定义的类进行继承,并重构__str__
calss TestStr(Test):
def __str__(self):
return '[TestStr: %s]' % self.data
>>> ts = TestStr()
>>> ts
<__main__.TestStr at 0x7fa91c314e50>
>>> print ts
[Value: hello, world!]
翻看一些资料,比较官方的解释是:str是面向用户的,得到的字符串可读性更好,而repr是面向哥的(程序猿),得到的字符串通常用来重新获取该对象。
repr和‘’在特性和功能上非常相似,事实是这个俩是双胞胎(做的是完全一样的事情),他们所返回的式一个对象的“官方”字符串表示。
此时不禁有疑问,既然有了repr,为什么还要('')?我也不懂。。。
在python核心编程上的解释是:python中有很多函数与操作符的功能是相同的。(你tm是逗我,我问你为什么要这么做你告诉我你有很多都是这么做的?!)之所以如此在某些场合函数回避操作符更加适合使用,例如在处理类似函数这样的可执行对象或者根据不同的数据项调用不同的函数处理时,函数会比操作符更加使用。(既然如此,为什么还要设置(‘’)操作符!坑我的把?)并且在python中也有很多函数与操作符的功能相同,最为常见的是××和pow()完成的都是乘方运算。(出处:python核心编程第二版中文P66)
我的猜想是,Guido在写的时候一定是先定义的操作符,之后为了pythonic,才又定义了一个相对直观的函数。
好了吃瓜的大婶们都回家吧~
PS:__str__和__repr__是类的内建函数,可重构,其作用是为了方便调试。功能和str、repr没有区别。