本文整理汇总了Python中copy_reg.dispatch_table方法的典型用法代码示例。如果您正苦于以下问题:Python copy_reg.dispatch_table方法的具体用法?Python copy_reg.dispatch_table怎么用?Python copy_reg.dispatch_table使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类copy_reg
的用法示例。
在下文中一共展示了copy_reg.dispatch_table方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: test_dispatch_table
# 需要导入模块: import copy_reg [as 别名]
# 或者: from copy_reg import dispatch_table [as 别名]
def test_dispatch_table(self):
result = copy_reg.dispatch_table
#CodePlex Work Item 8522
#self.assertEqual(5,len(result))
temp = {
"abc":"abc123",
"def":"def123",
"ghi":"ghi123"
}
copy_reg.dispatch_table = temp
self.assertEqual(temp,copy_reg.dispatch_table)
temp = {
1:"abc123",
2:"def123",
3:"ghi123"
}
copy_reg.dispatch_table = temp
self.assertEqual(temp,copy_reg.dispatch_table)
temp = {
1:123,
8:789,
16:45465
}
copy_reg.dispatch_table = temp
self.assertEqual(temp,copy_reg.dispatch_table)
#set dispathc_table as empty
temp ={}
copy_reg.dispatch_table = temp
self.assertEqual(temp,copy_reg.dispatch_table)
示例2: represent_object
# 需要导入模块: import copy_reg [as 别名]
# 或者: from copy_reg import dispatch_table [as 别名]
def represent_object(self, data):
# We use __reduce__ API to save the data. data.__reduce__ returns
# a tuple of length 2-5:
# (function, args, state, listitems, dictitems)
# For reconstructing, we calls function(*args), then set its state,
# listitems, and dictitems if they are not None.
# A special case is when function.__name__ == '__newobj__'. In this
# case we create the object with args[0].__new__(*args).
# Another special case is when __reduce__ returns a string - we don't
# support it.
# We produce a !!python/object, !!python/object/new or
# !!python/object/apply node.
cls = type(data)
if cls in copy_reg.dispatch_table:
reduce = copy_reg.dispatch_table[cls](data)
elif hasattr(data, '__reduce_ex__'):
reduce = data.__reduce_ex__(2)
elif hasattr(data, '__reduce__'):
reduce = data.__reduce__()
else:
raise RepresenterError("cannot represent an object", data)
reduce = (list(reduce)+[None]*5)[:5]
function, args, state, listitems, dictitems = reduce
args = list(args)
if state is None:
state = {}
if listitems is not None:
listitems = list(listitems)
if dictitems is not None:
dictitems = dict(dictitems)
if function.__name__ == '__newobj__':
function = args[0]
args = args[1:]
tag = u'tag:yaml.org,2002:python/object/new:'
newobj = True
else:
tag = u'tag:yaml.org,2002:python/object/apply:'
newobj = False
function_name = u'%s.%s' % (function.__module__, function.__name__)
if not args and not listitems and not dictitems \
and isinstance(state, dict) and newobj:
return self.represent_mapping(
u'tag:yaml.org,2002:python/object:'+function_name, state)
if not listitems and not dictitems \
and isinstance(state, dict) and not state:
return self.represent_sequence(tag+function_name, args)
value = {}
if args:
value['args'] = args
if state or not isinstance(state, dict):
value['state'] = state
if listitems:
value['listitems'] = listitems
if dictitems:
value['dictitems'] = dictitems
return self.represent_mapping(tag+function_name, value)
示例3: represent_object
# 需要导入模块: import copy_reg [as 别名]
# 或者: from copy_reg import dispatch_table [as 别名]
def represent_object(self, data):
# We use __reduce__ API to save the data. data.__reduce__ returns
# a tuple of length 2-5:
# (function, args, state, listitems, dictitems)
# For reconstructing, we calls function(*args), then set its state,
# listitems, and dictitems if they are not None.
# A special case is when function.__name__ == '__newobj__'. In this
# case we create the object with args[0].__new__(*args).
# Another special case is when __reduce__ returns a string - we don't
# support it.
# We produce a !!python/object, !!python/object/new or
# !!python/object/apply node.
cls = type(data)
if cls in copy_reg.dispatch_table:
reduce = copy_reg.dispatch_table[cls](data)
elif hasattr(data, '__reduce_ex__'):
reduce = data.__reduce_ex__(2)
elif hasattr(data, '__reduce__'):
reduce = data.__reduce__()
else:
raise RepresenterError("cannot represent object: %r" % data)
reduce = (list(reduce)+[None]*5)[:5]
function, args, state, listitems, dictitems = reduce
args = list(args)
if state is None:
state = {}
if listitems is not None:
listitems = list(listitems)
if dictitems is not None:
dictitems = dict(dictitems)
if function.__name__ == '__newobj__':
function = args[0]
args = args[1:]
tag = u'tag:yaml.org,2002:python/object/new:'
newobj = True
else:
tag = u'tag:yaml.org,2002:python/object/apply:'
newobj = False
function_name = u'%s.%s' % (function.__module__, function.__name__)
if not args and not listitems and not dictitems \
and isinstance(state, dict) and newobj:
return self.represent_mapping(
u'tag:yaml.org,2002:python/object:'+function_name, state)
if not listitems and not dictitems \
and isinstance(state, dict) and not state:
return self.represent_sequence(tag+function_name, args)
value = {}
if args:
value['args'] = args
if state or not isinstance(state, dict):
value['state'] = state
if listitems:
value['listitems'] = listitems
if dictitems:
value['dictitems'] = dictitems
return self.represent_mapping(tag+function_name, value)
示例4: represent_object
# 需要导入模块: import copy_reg [as 别名]
# 或者: from copy_reg import dispatch_table [as 别名]
def represent_object(self, data):
# We use __reduce__ API to save the data. data.__reduce__ returns
# a tuple of length 2-5:
# (function, args, state, listitems, dictitems)
# For reconstructing, we calls function(*args), then set its state,
# listitems, and dictitems if they are not None.
# A special case is when function.__name__ == '__newobj__'. In this
# case we create the object with args[0].__new__(*args).
# Another special case is when __reduce__ returns a string - we don't
# support it.
# We produce a !!python/object, !!python/object/new or
# !!python/object/apply node.
cls = type(data)
if cls in copyreg.dispatch_table:
reduce = copyreg.dispatch_table[cls](data)
elif hasattr(data, '__reduce_ex__'):
reduce = data.__reduce_ex__(2)
elif hasattr(data, '__reduce__'):
reduce = data.__reduce__()
else:
raise RepresenterError("cannot represent object: %r" % data)
reduce = (list(reduce)+[None]*5)[:5]
function, args, state, listitems, dictitems = reduce
args = list(args)
if state is None:
state = {}
if listitems is not None:
listitems = list(listitems)
if dictitems is not None:
dictitems = dict(dictitems)
if function.__name__ == '__newobj__':
function = args[0]
args = args[1:]
tag = u'tag:yaml.org,2002:python/object/new:'
newobj = True
else:
tag = u'tag:yaml.org,2002:python/object/apply:'
newobj = False
function_name = u'%s.%s' % (function.__module__, function.__name__)
if not args and not listitems and not dictitems \
and isinstance(state, dict) and newobj:
return self.represent_mapping(
u'tag:yaml.org,2002:python/object:'+function_name, state)
if not listitems and not dictitems \
and isinstance(state, dict) and not state:
return self.represent_sequence(tag+function_name, args)
value = {}
if args:
value['args'] = args
if state or not isinstance(state, dict):
value['state'] = state
if listitems:
value['listitems'] = listitems
if dictitems:
value['dictitems'] = dictitems
return self.represent_mapping(tag+function_name, value)
示例5: pyobjectEncode
# 需要导入模块: import copy_reg [as 别名]
# 或者: from copy_reg import dispatch_table [as 别名]
def pyobjectEncode(self, coder):
t = type(self)
# Find builtin support
f = encode_dispatch.get(t)
if f is not None:
f(coder, self)
return
# Check for a class with a custom metaclass
# NOTE: pickle.py catches TypeError here, that's for
# compatibility with ancient versions of Boost
# (before Python 2.2) and is not needed here.
issc = issubclass(t, type)
if issc:
save_global(coder, self)
return
# Check copyreg.dispatch_table
reduce = copyreg.dispatch_table.get(t)
if reduce is not None:
rv = reduce(self)
else:
reduce = getattr(self, "__reduce_ex__", None)
rv = reduce(2)
if type(rv) is str:
save_global(coder, self, rv)
return
if type(rv) is not tuple:
raise PicklingError("%s must return string or tuple" % reduce)
l = len(rv)
if not (2 <= l <= 5):
raise PicklingError(
"Tuple returned by %s must have two to " "five elements" % reduce
)
save_reduce(coder, *rv)