reprlib
— Альтернативная реализация repr()
¶
Исходный код: Lib/reprlib.py
Модуль reprlib
обеспечивает средство для производства представлений объекта
с ограничениями на размер получающегося строки. Он используется в отладчике
Python и может быть полезно и в других контекстах.
Модуль предоставляет класс, сущность и функцию:
-
class
reprlib.
Repr
¶ Класс, который предоставляет услуги форматирования, полезные в осуществлении функций, подобных встроенному
repr()
; добавляются ограничения по размеру для различных типов объектов, чтобы избежать создания чрезмерно длинных представлений.
-
reprlib.
aRepr
¶ Это - сущность
Repr
, который является используемый, чтобы обеспечить функциюrepr()
, описанную ниже. Изменение атрибуты этого объекта затронет пределы размера используемыйrepr()
и отладчиком Python.
-
reprlib.
repr
(obj)¶ Это метод
repr()
aRepr
. Это возвращает подобное строка этому возвращенный встроенной функцией того же имени, но с ограничениями на большинство размеров.
В дополнение к средствам ограничения размера модуль также предоставляет
декоратор для обнаружения рекурсивных вызовов __repr__()
и замены
местозаполнителя строка вместо него.
-
@
reprlib.
recursive_repr
(fillvalue="...")¶ Декоратор для методов
__repr__()
для обнаружения рекурсивных вызовов в пределах одного и того же поток. Если рекурсивный вызов сделан, fillvalue - возвращенный, иначе, обычный вызов__repr__()
сделан. Например:>>> 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'>
Добавлено в версии 3.2.
Объекты Repr¶
Repr
сущности предоставить несколько атрибуты, которые могут быть
используемый для обеспечения ограничений размера для представлений различных
типов объектов, и методов, которые форматируют конкретные типы объектов.
-
Repr.
maxlevel
¶ Ограничение глубины создания рекурсивных представлений. Значение по умолчанию -
6
.
-
Repr.
maxdict
¶ -
Repr.
maxlist
¶ -
Repr.
maxtuple
¶ -
Repr.
maxset
¶ -
Repr.
maxfrozenset
¶ -
Repr.
maxdeque
¶ -
Repr.
maxarray
¶ Ограничение количества записей, представленных для именованного типа объекта. По умолчанию -
4
дляmaxdict
,5
дляmaxarray
и6
для остальных.
-
Repr.
maxlong
¶ Максимальное число символов в представлении для целого числа. Цифры отбрасываются из середины. Значение по умолчанию -
40
.
-
Repr.
maxstring
¶ Ограничение на количество знаков в представлении строка. Обратите внимание, что «нормальное» представление строка является используемый в качестве источника символ: если в представлении необходимы escape-последовательности, они могут управляться при укорочении представления. Значение по умолчанию -
30
.
-
Repr.
maxother
¶ Этот предел - используемый, чтобы управлять размером типов объекта, для которых никакой определенный метод форматирования не доступен на объекте
Repr
. Он применяется таким же образом, как иmaxstring
. Значение по умолчанию -20
.
-
Repr.
repr1
(obj, level)¶ Рекурсивное внедрение используемый
repr()
. Это использует тип obj, чтобы определить который, форматируя метод, чтобы звонить, передавая ему obj и level. Методы, специфичные для типа, должны вызыватьrepr1()
для выполнения рекурсивного форматирования сlevel - 1
для значение level в рекурсивном вызове.
-
Repr.
repr_TYPE
(obj, level) Методы форматирования для определенных типов реализуются как методы с именем на основе имени типа. В имени метода TYPE заменяется на
'_'.join(type(obj).__name__.split())
. Отправка в эти методы обрабатываетсяrepr1()
. Специфичные для типа методы, которые должны рекурсивно форматировать значение, должны вызыватьself.repr1(subobj, level - 1)
.
Подклассирование объектов восстановления¶
Использование динамической диспетчеризации по Repr.repr1()
позволяет подклассы
Repr
добавлять поддержку дополнительных встроенных типов объектов или
изменять обработку уже поддерживаемых типов. В этом примере показано, как можно
добавить специальную поддержку файловых объектов:
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>'