我有一个通过xml-rpc发送字典的简单示例:
class CTest(object):
def __init__(self):
self.node1 = {'data':'zek', 'parent':{}, 'children':[]}
self.node2 = {'data':'bill', 'parent':{}, 'children':[]}
self.node1['children'].append(self.node2)
self.node2['parent'] = self.node1
def getNode(self):
return self.node1
我有两个字典:node2是node1的子级,同时node2将node1的引用作为父变量。所以它是一个递归字典。当我尝试通过XML-RPC发送node1时,我得到了以下异常:
#Command to execute xml-rpc dump method for serialization
test = CTest()
xmlrpclib.dumps((test,), 'Node Object')
#Exception
raise TypeError, "cannot marshal recursive dictionaries"
是否可以通过XML-RPC发送node1(不改变字典结构)?
谢谢。
使用Python的"pickle"模块自行序列化和反序列化"test"。
cPickle.dumps(test)
正在工作。在电线的另一侧,您使用
cPickle.loads(received_test_pickle)
可能需要在XMLRPC调用之前/之后对pickle进行base-64编码/解码。
但也要看看PyRo
http://pyro.sourceforge.net/