使用pprint模块打印对象时,是否有任何干净的方法来抑制Unicode字符前缀?
>>> import pprint
>>> pprint.pprint({u'foo': u'bar', u'baz': [u'apple', u'orange', u'pear', u'guava', u'banana'], u'hello': u'world'})
{u'baz': [u'apple', u'orange', u'pear', u'guava', u'banana'],
u'foo': u'bar',
u'hello': u'world'}
这看起来很丑。有什么方法可以打印每个对象的__str__值,而不是__repr__吗?]
可以通过重写PrettyPrinter对象的format方法,并将任何unicode对象转换为字符串来完成:
import pprint
def my_safe_repr(object, context, maxlevels, level):
typ = pprint._type(object)
if typ is unicode:
object = str(object)
return pprint._safe_repr(object, context, maxlevels, level)
printer = pprint.PrettyPrinter()
printer.format = my_safe_repr
printer.pprint({u'foo': u'bar', u'baz': [u'apple', u'orange', u'pear', u'guava', u'banana'], u'hello': u'world'})
给出:
{'baz': ['apple', 'orange', 'pear', 'guava', 'banana'],
'foo': 'bar',
'hello': 'world'}
这可能太多了,但是一种可能的方法是在输出流上实现包装器:
import pprint,sys,re
class writer :
def write(self, text):
text=re.sub(r'u\'([^\']*)\'', r'\1',text)
sys.stdout.write(text)
wrt=writer()
d = { u'foo': u'bar', u'baz':
[u'apple', u'orange', u'pear', u'guava', u'banana'],
u'hello': u'world'}
pp = pprint.PrettyPrinter(stream=wrt)
pp.pprint(d)
输出:
{baz: [apple, orange, pear, guava, banana],
foo: bar,
hello: world}
也有可能在父母中加引号,以便在字符串周围使用单引号,例如'foo':'bar':
text=re.sub(r'u(\'[^\']*\')', r'\1',text)
这给:
{'baz': ['apple', 'orange', 'pear', 'guava', 'banana'],
'foo': 'bar',
'hello': 'world'}
否,pprint打印表示。这不是为了做出漂亮的最终用户输出,而是以一种可读的方式打印Python对象。
pprint模块提供了对任意对象进行“漂亮打印”的功能Python数据结构的形式可用作输入口译员。
(很多年以后回答)
只需使用python3。默认情况下,所有标准字符串都是unicode,因此没有u前缀。