copyreg —注册 pickle 支持Function

源代码: Lib/copyreg.py


copyreg模块提供了一种定义在腌制特定对象时使用的Function的方法。腌制/复制这些对象时,picklecopy模块使用这些Function。该模块提供有关不是类的对象构造函数的配置信息。这样的构造函数可以是工厂函数或类实例。

  • copyreg. constructor(* object *)

    • 语句* object 为有效的构造函数。如果 object *是不可调用的(因此作为构造函数无效),则引发TypeError
  • copyreg. pickle(* type function constructor = None *)

    • 语句* function 应该用作 type *类型对象的“归约”函数。 * function *应该返回包含两个或三个元素的字符串或 Tuples。

可选的* constructor 参数(如果提供)是一个可调用对象,当在 Pickling 时使用 function 返回的参数 Tuples 进行调用时,可用于重建对象。如果 object 是一个类或 constructor *是不可调用的,则将引发TypeError

请参阅pickle模块,以获取* function constructor *所需的接口的更多详细信息。请注意,pickler 对象的dispatch_table属性或pickle.Pickler的子类也可以用于语句归约函数。

Example

下面的示例想显示如何注册一个 pickle 函数以及如何使用它:

>>> import copyreg, copy, pickle
>>> class C(object):
...     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...