python deepcopy报错_python 字典对象赋值之deepcopy遭遇的问题及解决过程(lxml惹的祸)...
今天在寫一段代碼的時候,需要對字典進行傳值操作。
一般情況下字典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
結果打印是
這時候我大致明白了,原來我系統中引用了lxml庫。
所以type(x)的時候就找到這個類,而copy模塊里邊沒有針對這種對象的處理。
最后代碼修改如下
158 cls = type(x)
159 if cls == lxml.etree._Attrib:
160 cls = dict
總結
以上是生活随笔為你收集整理的python deepcopy报错_python 字典对象赋值之deepcopy遭遇的问题及解决过程(lxml惹的祸)...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ieee39节点系统介绍_Java秒杀系
- 下一篇: 用python实现打开虚拟机_如何使用p