0

我不知道如何序列化。从网上冲浪了解到,dill 可以序列化函数和类。我在下面有一个示例,其中有两个类,每个类都有一些具有不同参数的函数。我想将它们全部序列化。有人可以帮我解决这个问题吗

class dummy_class_1:
   def dummy_func_1(self,master):
    ..

   def dummy_func_2(self):
    ...

class dummy_class_2:
    def dummy_func_3(self,event):
    ...

    def dummy_func_4(self):
    ...
4

1 回答 1

0

如果你想一起序列化这些类,那么你可以dump把它们变成一个字符串:

>>> class dummy_class_1(object):
...   def dummy_func_1(self, master):
...     return
...   def dummy_func_2(self):
...     return
... 
>>> class dummy_class_2(object):
...   def dummy_func_3(self, event):
...     return
...   def dummy_func_4(self):
...     return
... 
>>> import dill
>>>          
>>> dill.dumps((dummy_class_1, dummy_class_2))
'\x80\x02cdill.dill\n_create_type\nq\x00(cdill.dill\n_load_type\nq\x01U\x08TypeTypeq\x02\x85q\x03Rq\x04U\rdummy_class_1q\x05h\x01U\nObjectTypeq\x06\x85q\x07Rq\x08\x85q\t}q\n(U\n__module__q\x0bU\x08__main__q\x0cU\x0cdummy_func_1q\rcdill.dill\n_create_function\nq\x0e(cdill.dill\n_unmarshal\nq\x0fUpc\x02\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00C\x00\x00\x00s\x04\x00\x00\x00d\x00\x00S(\x01\x00\x00\x00N(\x00\x00\x00\x00(\x02\x00\x00\x00t\x04\x00\x00\x00selft\x06\x00\x00\x00master(\x00\x00\x00\x00(\x00\x00\x00\x00s\x07\x00\x00\x00<stdin>t\x0c\x00\x00\x00dummy_func_1\x02\x00\x00\x00s\x02\x00\x00\x00\x00\x01q\x10\x85q\x11Rq\x12c__builtin__\n__main__\nh\rNN}q\x13tq\x14Rq\x15U\x0cdummy_func_2q\x16h\x0e(h\x0fUec\x01\x00\x00\x00\x01\x00\x00\x00\x01\x00\x00\x00C\x00\x00\x00s\x04\x00\x00\x00d\x00\x00S(\x01\x00\x00\x00N(\x00\x00\x00\x00(\x01\x00\x00\x00t\x04\x00\x00\x00self(\x00\x00\x00\x00(\x00\x00\x00\x00s\x07\x00\x00\x00<stdin>t\x0c\x00\x00\x00dummy_func_2\x04\x00\x00\x00s\x02\x00\x00\x00\x00\x01q\x17\x85q\x18Rq\x19c__builtin__\n__main__\nh\x16NN}q\x1atq\x1bRq\x1cU\x07__doc__q\x1dNutq\x1eRq\x1fh\x00(h\x04U\rdummy_class_2q h\x08\x85q!}q"(h\x0bh\x0cU\x0cdummy_func_3q#h\x0e(h\x0fUoc\x02\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00C\x00\x00\x00s\x04\x00\x00\x00d\x00\x00S(\x01\x00\x00\x00N(\x00\x00\x00\x00(\x02\x00\x00\x00t\x04\x00\x00\x00selft\x05\x00\x00\x00event(\x00\x00\x00\x00(\x00\x00\x00\x00s\x07\x00\x00\x00<stdin>t\x0c\x00\x00\x00dummy_func_3\x02\x00\x00\x00s\x02\x00\x00\x00\x00\x01q$\x85q%Rq&c__builtin__\n__main__\nh#NN}q\'tq(Rq)U\x0cdummy_func_4q*h\x0e(h\x0fUec\x01\x00\x00\x00\x01\x00\x00\x00\x01\x00\x00\x00C\x00\x00\x00s\x04\x00\x00\x00d\x00\x00S(\x01\x00\x00\x00N(\x00\x00\x00\x00(\x01\x00\x00\x00t\x04\x00\x00\x00self(\x00\x00\x00\x00(\x00\x00\x00\x00s\x07\x00\x00\x00<stdin>t\x0c\x00\x00\x00dummy_func_4\x04\x00\x00\x00s\x02\x00\x00\x00\x00\x01q+\x85q,Rq-c__builtin__\n__main__\nh*NN}q.tq/Rq0h\x1dNutq1Rq2\x86q3.'

或者,您可以dump将它们保存到文件中...

>>> with open('dummy.pkl', 'wb') as f:
...   dill.dump(dummy_class_1, f)
...   dill.dump(dummy_class_2, f)
... 
>>>

然后当你重新启动时,你可以load

Python 2.7.10 (default, Sep  2 2015, 17:36:25) 
[GCC 4.2.1 Compatible Apple LLVM 5.1 (clang-503.0.40)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import dill
>>> with open('dummy.pkl', 'rb') as f:
...   dummy_class_1 = dill.load(f)
...   dummy_class_2 = dill.load(f)
... 
>>> print dill.source.getsource(dummy_class_1)
class dummy_class_1(object):
  def dummy_func_1(self, master):
    return
  def dummy_func_2(self):
    return

>>> 

类方法(即类中的函数)只会在类中序列化。

请注意,我在回复中使用了 python 2.7,但它对 python 3.x 的工作方式完全相同。

于 2015-11-07T12:35:13.587 回答