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

<p>今天在写一段代码的时候,需要对字典进行传值操作。</p>
<p>一般情况下字典a = 字典b,意味着是传引用,b发送改变的情况下a也会发生改变。</p>
<p>我的字典如下</p>
<p>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}}]}}]}}</p>
<p></p>
<p>调用代码如下</p>
<p>import copy</p>
<p>copy.deepcopy(a)</p>
<p></p>
<p>结果在代码调试的时候老是报</p>
<p>'__cinit__() takes exactly 1 positional argument (0 given)</p>
<p></p>
<p>神奇的是如果单独启动个python,把a字典赋值然后调用copy.deepcopy(a)是正常的,但是如果在项目中使用就报如上错误</p>
<p></p>
<p>看着python的这个提示真是让人丈二和尚摸不着头脑,明明传了参数的为何报没有参数传递呢。如大家所知python报错机制比较乱的,往往把</p>
<p>子函数的错误在调度的地方直接抛出来。所以最后的办法,只能直接debug,还好copy模块的代码也是开源的,一行一行debug.</p>
<p>结果发现代码中有个地方如下:</p>
<p>cls = type(x)</p>
<p>而x是我传入字典的子对象{'classname': 'testdemo', 'circles': '2', 'casecode': 'case02', 'description': u'/u6d4b/u8bd5/u51c6/u590702'}</p>
<p>按道理这个对象也应该是dict</p>
<p>结果打印是<type 'lxml.etree._Attrib'></p>
<p>这时候我大致明白了,原来我系统中引用了lxml库。</p>
<p>所以type(x)的时候就找到这个类,而copy模块里边没有针对这种对象的处理。</p>
<p>最后代码修改如下</p>
<p>158 cls = type(x)<br>
159 if cls == lxml.etree._Attrib:<br>
160 cls = dict</p>
<p></p>
<p></p>
<p></p>
<p></p>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值