python 字典对象赋值之deepcopy遭遇的问题及解决过程(lxml惹的祸)

来源:互联网 发布:数组指针例子 编辑:程序博客网 时间:2024/06/06 18:38

今天在写一段代码的时候,需要对字典进行传值操作。

一般情况下字典a = 字典b,意味着是传引用,b发送改变的情况下a也会发生改变。

我的字典如下

a={'testcase': {'attributes': {'classname': 'testdemo', 'circles': '2', 'casecode': 'case02', 'description': u'/u6d4b/u8bd5/u51c6/u590702'}, 'value': [{'step': {'attributes': {'stepid': '01', 'type': 'actor', 'method': 'prepareurl', 'description': u'/u51c6/u5907/u670d/u52a1/u5668/u5730/u5740'}, 'value': [{'inputdata': {'attributes': {'value': 'http://10.249.128.122:8180/top/ecs/DayOnlineTimes.do?', 'key': 'url'}, 'value': None}}]}}]}}

 

调用代码如下

import copy

copy.deepcopy(a)

 

结果在代码调试的时候老是报

'__cinit__() takes exactly 1 positional argument (0 given)

 

神奇的是如果单独启动个python,把a字典赋值然后调用copy.deepcopy(a)是正常的,但是如果在项目中使用就报如上错误

 

看着python的这个提示真是让人丈二和尚摸不着头脑,明明传了参数的为何报没有参数传递呢。如大家所知python报错机制比较乱的,往往把

子函数的错误在调度的地方直接抛出来。所以最后的办法,只能直接debug,还好copy模块的代码也是开源的,一行一行debug.

结果发现代码中有个地方如下:

cls = type(x)

而x是我传入字典的子对象{'classname': 'testdemo', 'circles': '2', 'casecode': 'case02', 'description': u'/u6d4b/u8bd5/u51c6/u590702'}

按道理这个对象也应该是dict

结果打印是<type 'lxml.etree._Attrib'>

这时候我大致明白了,原来我系统中引用了lxml库。

所以type(x)的时候就找到这个类,而copy模块里边没有针对这种对象的处理。

最后代码修改如下

158     cls = type(x)
159     if cls == lxml.etree._Attrib:
160         cls = dict

 

 

 

 

原创粉丝点击