前言
代码示例
下面我们用例子来说明两个函数是差异点,还有就是print输出字符串时需要注意的点
将整型转换为字符串
>>> a = 123 #int类型 >>> type(a)
>>> str(a) '123' >>> type(str(a))
>>> print(str(a)) #print输出时会去掉引号,但是仍然是str类型 123 >>> repr(a) '123' >>> type(repr(a))
>>> print(repr(a)) 123 >>> len(repr(a)) #转换后的数据都是'123',所以长度是3 3 >>> len(str(a)) #转换后的数据都是'123',所以长度是3 3
将字符串再转换为字符串
>>> repr('abd') #repr转换后是在'abd'的外层又加了一层引号 "'abd'" >>> str('abd') #str转换后还是原来的值 'abd' >>> str('abd') == 'abd' True >>> repr('abd') == 'abd' False >>> len(repr('abd')) #repr转换后的字符串和str转换后的字符串个数都是不一样的 5 >>> len(str('abd')) 3
命令行下print和直接输出的对比
每个类都有默认的__repr__, __str__方法,在命令行下用print 实例时调用的是类的str方法,直接调用的是类的repr方法;在文件模式下没有print的话是不会有输出值的,自己定义一个类A,验证以上结论:
>>> class A(): ... def __repr__(self): ... return 'repr' ... def __str__(self): ... return 'str' ... >>> a = A() >>> a #直接输出调用的是repr方法 repr >>> print(a) #print调用的是str方法 str
repr的使用场景
根据以上代码示例,可以得出只有当repr再次作用在字符串上时会多一层引号,那么这一特性在拼接完字符串用eval执行时是特别有用的,如果不用repr而是采用str会报错,举例,将字符串s = ‘abdcf’转换成列表,如果用eval自己实现的话可以这样写:
>>> s = 'abdcf' >>> eval('['+','.join([repr(i) for i in s])+']') ['a', 'b', 'd', 'c', 'f'] >>> eval('['+','.join([str(i) for i in s])+']') #str报错 Traceback (most recent call last): File "
", line 1, in
File "
", line 1, in
NameError: name 'b' is not defined
为什么会报错呢?当’,’.join([str(i) for i in s])拼接后的结果‘a,b,d,c,f’只有一层引号,eval执行时会去掉这层引号,就成了a,b,d,c,f,解释器就会当做变量对待,但是并没有定义这样的变量,所以报NameError错误
>>> ','.join([repr(i) for i in s]) "'a','b','d','c','f'" >>> ','.join([str(i) for i in s]) 'a,b,d,c,f' >>>
总结
1.除了字符串类型外,使用str还是repr转换没有什么区别,字符串类型的话,外层会多一对引号,这一特性有时候在eval操作时特别有用;
2.命令行下直接输出对象调用的是对象的repr方法,print输出调用的是str方法
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/225587.html原文链接:https://javaforall.net
