copyreg --- 註冊pickle 支援函式

原始碼:Lib/copyreg.py


copyreg 模組提供了一種用以定義在 pickle 特定物件時使用之函式的方式。picklecopy 模組在 pickle/copy 這些物件時使用這些函式。此模組提供有關非類別物件之建構函式的配置資訊。此類建構函式可以是工廠函式 (factory function) 或類別實例。

copyreg.constructor(object)

宣告object 是一個有效的建構函式。如果object 不可呼叫(因此不可作為有效的建構函式),則會引發TypeError

copyreg.pickle(type,function,constructor_ob=None)

宣告function 應該用作type 型別之物件的「歸約 ("reduction")」函式。function 必須回傳字串或包含 2 到 6 個元素的元組。有關function 介面的更多詳細資訊,請參閱dispatch_table

constructor_ob 參數是一個遺留功能,現在已被忽略,但如果要傳遞它的話則必須是個可呼叫物件。

請注意,pickler 物件或pickle.Pickler 子類別的dispatch_table 屬性也可用於宣告歸約函式。

範例

下面範例展示如何註冊一個 pickle 函式以及如何使用它:

>>>importcopyreg,copy,pickle>>>classC:...def__init__(self,a):...self.a=a...>>>defpickle_c(c):...print("pickling a C instance...")...returnC,(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...