设计目的区别
有两个函数可用于获取对象的可读表示 ,常用于打印输出及类型转换:
repr(x) : 结合eval函数使用通常会将该变量的结果转换回原始对象,即将对象转化为供编译器(即机器)读取的形式。
str(x) : 返回描述对象的可读字符串(即人类可读),由于会自动类型转换,这可能隐藏了一些技术转换细节。
补充:eval
补充介绍:eval()
函数用来执行一个字符串表达式,并返回表达式的值
如下代码:
x = 7
eval( '3 * x' )
#输出:21
注:
- repr()对于许多变量类型,此函数尝试返回一个字符串,它会尽量把原始相同的值作为参数传递给其他函数,比如结合eval()函数使用;同时它会传递一些其它的信息,包括名称、所在内存地址等等对象信息,以保证变量的原始传递,而不丢失机器信息。
- str()对于字符串,它返回字符串本身。这与repr(object)的区别在于,str(object)并不总是试图返回一个eval()可以接受的字符串。相反,它的目标是返回一个可打印的或“人类可读的”字符串。如果没有给出参数,则返回空字符串。
示例
举例1:
s = """w'o"w"""
repr(s) # 输出: '\'w\\'o"w\''
str(s)
#输出: 'w\'o"w'
eval(str(s)) == s # 报语法错误
eval(repr(s)) == s # 输出:True
举例2:
import datetime
today = datetime.datetime.now()
str(today)
#输出: '2016-09-15 06:58:46.915000'
repr(today)
# 输出: 'datetime.datetime(2016, 9, 15, 6, 58, 46, 915000)'
看到没有,人类可读和机器可读其实有本质的区别
实践
在编写类时,你可以覆盖这些方法来做任何你想做的事情 :
class Represent(object):
def __init__(self, x, y):#注:__init_是类class的构造函数
self.x, self.y = x, y
def __repr__(self):
return "Represent(x={},y=\"{}\")".format(self.x, self.y)
def __str__(self):
return "Representing x as {} and y as {}".format(self.x, self.y)
使用上面的类,我们可以看到以下结果:
r = Represent(1, "Hopper")
print(r)
#打印默认调用了__str__函数
print(r.__repr__)
# 显式调用了 __repr__方法,打印了: '<bound method Represent.repr ofRepresent(x=1,y="Hopper")'
#返回结果有点难懂,不用管,反正就是机器可以读懂
rep = r.__repr__()
# 将__repr__函数的返回值,赋值给了rep变量
print(rep)
#由于调用了print函数,所以自动调用了str函数,将返回变成了人类可读的
#打印 'Represent(x=1,y="Hopper")'
r2 = eval(rep) # 返回表达式结果
print(r2)
#按照__str__里面的格式输出,因为print默认调用的是str函数
print(r2 == r)
#输出false,因为这两个已经是完全不同的对象