copyreg — Register pickle support functions¶
Código fuente: Lib/copyreg.py
El módulo copyreg ofrece una manera de definir las funciones usadas cuando se serializan (pickling) objetos específicos. Los módulos pickle y copy utilizan estas funciones cuando se realizan acciones de serializado/copiado en esos objetos. El módulo provee información de configuración acerca de los objetos constructores, los cuales no son clases. Estos objetos constructores pueden ser funciones-fábrica o instancias de clase.
- copyreg.constructor(object)¶
- Declara que el object es un constructor válido. Si el object no es invocable (y por lo tanto, no es válido como constructor), lanza una excepción - TypeError.
- copyreg.pickle(type, function, constructor_ob=None)¶
- Declares that function should be used as a «reduction» function for objects of type type. function must return either a string or a tuple containing between two and six elements. See the - dispatch_tablefor more details on the interface of function.- El parámetro constructor_ob es una característica heredada y ahora se ignora, pero si se pasa debe ser invocable. - Note que el atributo - dispatch_tablede un objeto pickler o subclase de- pickle.Picklertambién puede ser utilizado para declarar funciones de reducción.
Ejemplo¶
El siguiente ejemplo pretende mostrar cómo registrar una función pickle y cómo se utilizará:
>>> import copyreg, copy, pickle
>>> class C:
...     def __init__(self, a):
...         self.a = a
...
>>> def pickle_c(c):
...     print("pickling a C instance...")
...     return C, (c.a,)
...
>>> copyreg.pickle(C, pickle_c)
>>> c = C(1)
>>> d = copy.copy(c)
pickling a C instance...
>>> p = pickle.dumps(c)
pickling a C instance...