首先我们来举个例子,定义一个长方行类Cuboid,长为x,宽为y,高为z

class Cuboid:

    def __init__(self, x = 3, y = 1, z = 2):
self.x = x
self.y = y
self.z = z

默认长为3,宽为1,高为2,让我们试图打印一下这个类

print(Cuboid())

控制台可能会输出:

<__main__.Cuboid object at 0x0000025EE2A9AA90>

但是如果在类种实现__repr__或者__str__如下

class Cuboid:

    def __init__(self, x = 3, y = 1, z = 2):
self.x = x
self.y = y
self.z = z def __repr__(self):
return 'Vector(%r, %r, %r)'%(self.x, self.y, self.z) print(Cuboid())

或者

class Cuboid:

    def __init__(self, x = 3, y = 1, z = 2):
self.x = x
self.y = y
self.z = z def __str__(self):
return 'Vector(%s, %s, %s)'%(self.x, self.y, self.z) print(Cuboid())

输出结果都将是

Vector(3, 1, 2)

也就是说repr与str都是python的内置函数,他们能把一个对象用字符串的形式表达出来,这就是字符串表达形式。repr,str分别是通过__repr__和__str__这两个特殊方法来实现的。

区别:

__repr__和__str__的区别在于,后者是通过str()函数被使用,或者说是只用print打印一个对象时才会别调用。

如果在一个对象中只想保留两者中的一个,那么最好是__repr__,因为当一个对象没有__str__,而python有需要调用它时,往往会用__repr__来替换__str__。

更多大牛解答:

https://stackoverflow.com/questions/1436703/difference-between-str-and-repr

import datetime

now = datetime.datetime.now()

print(str(now))
#输出
2018-07-20 19:02:59.546306 print(repr(now))
#输出
datetime.datetime(2018, 7, 20, 19, 2, 59, 546306)

__repr__具有明确无误性,面向开发人员,而__str__具有可读性,面型用户。

上面长方体类中的%r与%s也是一样

在一些情况下

print(It is '%s' % 7)
print(It is '%r' % 7)
print(It is '%d' % 7)

三种输出是一样的

但是下面情况

import datetime
d = datetime.date.today()
print( "%s" % d )
#输出
2018-07-20 19:02:59.546306 print ( "%r" % d )
#输出
datetime.datetime(2018, 7, 20, 19, 2, 59, 546306)

%r打印时能够重现它所代表的对象,因此可以表达的更清楚正确。

总结一句话就是

__str__()魔法方法与print()输出函数搭配,并且返回值只能为一个字符串类型

__repr__()其返回值是在交互式解释中起作用

__repr__与__str__的更多相关文章

  1. [转]Python中__repr__和__str__区别

    class Test(object): def __init__(self, value='hello, world!'): self.data = value >>> t = Te ...

  2. Python中__repr__和__str__区别

    Python中__repr__和__str__区别 看下面的例子就明白了 class Test(object): def __init__(self, value='hello, world!'): ...

  3. raindi python魔法函数(一)之__repr__与__str__

    __repr__和__str__都是python中的特殊方法,都是用来输出实例对象的,如果没有定义这两个方法在打印的时候只会输出实例所在的内存地址 这种方式的输出没有可读性,并不能直观的体现实例.py ...

  4. Python中__repr__和__str__区别(转)

    class Test(object): def __init__(self, value='hello, world!'): self.data = value >>> t = Te ...

  5. Python面试题之Python中__repr__和__str__区别

    看下面的例子就明白了 class Test(object): def __init__(self, value='hello, world!'): self.data = value >> ...

  6. Python3中__repr__和__str__区别

    示例: class Test(object): def __init__(self, value='hello, world!'): self.data = value >>> t ...

  7. class类 __repr__ 与__str__

    >>> class Student(object):... def __init__(self, name):... self.name = name... def __str__( ...

  8. python中的 __repr__和__str__

    __repr__,被内置函数repr用于把一个对象用"官方"的字符串形式表示出来(终端友好)    1.值传给eval()来返回一个对象的字符串表示形式    2.否则返回一个尖括 ...

  9. Python中的魔法函数__repr__和__str__的实质性区别

    str 和 repr 方法:是自定义类的字符串描述,这两种都是比较 Pythonic 的方式去控制对象转化为字符串的方式. 调用这两个方法,返回的都是字符串.但是这两个方法又有一些区别 ** 1 两种 ...

随机推荐

  1. C#6.0语言规范(五) 变量

    变量代表存储位置.每个变量都有一个类型,用于确定可以在变量中存储的值.C#是一种类型安全的语言,C#编译器保证存储在变量中的值始终是适当的类型.可以通过赋值或使用++和--运算符来更改变量的值. 必须 ...

  2. powerDesigner 把name项添加到注释(comment)

    第一次写博客,分享一点经验吧,平时大家用powerDesigner的时候,pd是不会把name项默认添加到comment的,所以生成的数据库表里面也没有中文字段的注释. 我在网上查了一下.有解决方案了 ...

  3. MySQL字符集的设置

    Notice:文章基于ubuntu系统而写 1.关于MySQL字符集 MySQL的字符集支持(Character Set Support)有两个方面: 字符集(Character set)和排序方式( ...

  4. flask框架1

    说flask框架之前,必须得提一下web框架,他的作用是为了利用互联网交流工作文档,我们为什么要使用框架,因为框架的稳定性和可扩展性强并且可以降低开发难度,提高开发效率.总的来说就是避免做无用功,重复 ...

  5. Python如何判断字符串中是否有中文

    解决:Python如何判断字符串中是否有中文 In [240]: s Out[240]: '你好aa' In [241]: for i in s: ...: if u'\u4e00' <= i ...

  6. linq查询时查询语句中附带多个查询时“已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭”

    主要原因是因为EF采用的 DataReader来进行数据的存储,此时connection使用的是同一个. 例如: list = _tzNewsService.GetAll().Where(w => ...

  7. oracle跨平台数据迁移 expdp/impdp 字符集问题 导致ORA-02374 ORA-12899 ORA-02372

    环境描述: 源数据库环境:     操作系统:Windows SERVER 2008R2     数据库版本:单实例 ORACLE 11.2.0.1 目标端数据库环境:     操作系统:redhat ...

  8. 九浅一深ThreadLocal

    ThreadLocal的作用.使用示例 ThreadLocal是线程的本地存储,存储在其内的值只能被当前线程访问到,其他线程获取不到,可以存储任意对象.经常用来存储当前线程的一些上下文信息,这样不用通 ...

  9. [转载]sql server 分布式查询

    --用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB' ,'sq ...

  10. 解决Maven的Could not resolve archetype org.apache.maven.archetypes:maven-archetype-quickstart

    eclipse配置好了Maven,创建maven-archetype-quickstart项目报错如下: Could not resolve archetype org.apache.maven.ar ...