reprlib
— Implementação alternativa à repr()
¶
Código-fonte: Lib/reprlib.py
The reprlib
module provides a means for producing object representations
with limits on the size of the resulting strings. This is used in the Python
debugger and may be useful in other contexts as well.
Este módulo fornece uma classe, uma instância e uma função.
-
class
reprlib.
Repr
¶ Classe que fornece serviços de formatação úteis na implementação de funções semelhantes à embutida
repr()
; limites de tamanho para diferentes tipos de objetos são adicionados para evitar a geração de representações excessivamente longas.
-
reprlib.
aRepr
¶ Esta é uma instância de
Repr
que é usada para fornecer a funçãorepr()
descrita abaixo. Alterar os atributos deste objeto afetará os limites de tamanho usados porrepr()
e pelo depurador Python.
-
reprlib.
repr
(obj)¶ Este é o método
repr()
deaRepr
. Ele retorna uma string semelhante à retornada pela função embutida de mesmo nome, mas com limites na maioria dos tamanhos.
In addition to size-limiting tools, the module also provides a decorator for
detecting recursive calls to __repr__()
and substituting a placeholder
string instead.
-
@
reprlib.
recursive_repr
(fillvalue='...')¶ Decorator for
__repr__()
methods to detect recursive calls within the same thread. If a recursive call is made, the fillvalue is returned, otherwise, the usual__repr__()
call is made. For example:>>> from reprlib import recursive_repr >>> class MyList(list): ... @recursive_repr() ... def __repr__(self): ... return '<' + '|'.join(map(repr, self)) + '>' ... >>> m = MyList('abc') >>> m.append(m) >>> m.append('x') >>> print(m) <'a'|'b'|'c'|...|'x'>
Novo na versão 3.2.
Objetos Repr¶
Instâncias Repr
fornecem vários atributos que podem ser usados para fornecer limites de tamanho para as representações de diferentes tipos de objetos e métodos que formatam tipos de objetos específicos.
-
Repr.
maxlevel
¶ Limite de profundidade na criação de representações recursivas. O padrão é
6
.
-
Repr.
maxdict
¶ -
Repr.
maxlist
¶ -
Repr.
maxtuple
¶ -
Repr.
maxset
¶ -
Repr.
maxfrozenset
¶ -
Repr.
maxdeque
¶ -
Repr.
maxarray
¶ Limites no número de entradas representadas para o tipo de objeto nomeado. O padrão é
4
paramaxdict
,5
paramaxarray
e6
para os demais.
-
Repr.
maxlong
¶ Número máximo de caracteres na representação para um inteiro. Os dígitos são omitidos a partir do meio. O padrão é
40
.
-
Repr.
maxstring
¶ Limite no número de caracteres na representação da string. Observe que a representação “normal” da string é usada como fonte de caracteres: se sequências de escape forem necessárias na representação, elas poderão ser distorcidas quando a representação for encurtada. O padrão é
30
.
-
Repr.
maxother
¶ Este limite é usado para controlar o tamanho de tipos de objetos para os quais nenhum método de formatação específico está disponível no objeto
Repr
. Ele é aplicado de maneira semelhante amaxstring
. O padrão é20
.
-
Repr.
repr1
(obj, level)¶ Implementação recursiva usada por
repr()
. Esta usa o tipo de obj para determinar qual método de formatação chamar, passando obj e level. Os métodos específicos de tipo devem chamarrepr1()
para realizar a formatação recursiva, comlevel - 1
para o valor de level na chamada recursiva.
-
Repr.
repr_TYPE
(obj, level) Métodos de formatação para tipos específicos são implementados como métodos com um nome baseado no nome do tipo. No nome do método, TYPE é substituído por
'_'.join(type(obj).__name__.split())
. O despacho para esses métodos é tratado porrepr1()
. Métodos específicos de tipo que precisam formatar um valor recursivamente devem chamarself.repr1(subobj, level - 1)
.
Estendendo objetos Repr¶
The use of dynamic dispatching by Repr.repr1()
allows subclasses of
Repr
to add support for additional built-in object types or to modify
the handling of types already supported. This example shows how special support
for file objects could be added:
import reprlib
import sys
class MyRepr(reprlib.Repr):
def repr_TextIOWrapper(self, obj, level):
if obj.name in {'<stdin>', '<stdout>', '<stderr>'}:
return obj.name
return repr(obj)
aRepr = MyRepr()
print(aRepr.repr(sys.stdin)) # prints '<stdin>'