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__()
для обнаружения рекурсивных вызовов в пределах одного потока. Если выполняется рекурсивный вызов, возвращается значение файла, в противном случае выполняется обычный вызов__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
¶ Ограничение на количество символов в представлении строки. Обратите внимание, что в качестве источника символов используется «нормальное» представление строки: если в представлении необходимы управляющие последовательности, они могут быть искажены при сокращении представления. По умолчанию используется значение
30
.
-
Repr.
maxother
¶ Это ограничение используется для контроля размера типов объектов, для которых не доступен конкретный метод форматирования объекта
Repr
. Оно применяется аналогичноmaxstring
. По умолчанию используется значение20
.
-
Repr.
repr
(obj)¶ Эквивалент встроенного
repr()
, который использует форматирование, налагаемое экземпляром.
-
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¶
Использование динамической диспетчеризации в 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>'