python字典append_python中字典重復賦值,append到list中引發的異常

今天遇到了一個關于python 字典的誤用。先上代碼:

data = [{'id': '1', 'name': '管理員', 'role': 'admin', 'desc': '系統管理員', 'acl': None},

{'id': '2', 'name': '研發', 'role': 'dev', 'desc': '研發人員', 'acl': None},

{'id': '3', 'name': '測試', 'role': 'qa', 'desc': '測試人員', 'acl': None},

{'id': '4', 'name': '項目經理', 'role': 'pm', 'desc': '項目經理', 'acl': None},

{'id': '5', 'name': '產品經理', 'role': 'po', 'desc': '產品經理', 'acl': None},

{'id': '6', 'name': '研發主管', 'role': 'td', 'desc': '研發主管', 'acl': None},

{'id': '7', 'name': '產品主管', 'role': 'pd', 'desc': '產品主管', 'acl': None},

{'id': '8', 'name': '測試主管', 'role': 'qd', 'desc': '測試主管', 'acl': None},

{'id': '9', 'name': '高層管理', 'role': 'top', 'desc': '高層管理', 'acl': None},

{'id': '10', 'name': '其他', 'role': 'others', 'desc': '其他', 'acl': None},

{'id': '11', 'name': 'guest', 'role': 'guest', 'desc': 'For guest', 'acl': None},

{'id': '12', 'name': '受限用戶', 'role': 'limited', 'desc': '受限用戶分組(只能編輯與自己相關的內容)', 'acl': None}]

depts = []

tmp_dept = {}

tmp_role = {}

roles = []

for i in data:

print (i)

tmp_dept["name"] = i["name"]

tmp_dept["id"] = i["id"]

tmp_role["name"] = i["name"]

tmp_role["role"] = i["role"]

depts.append(tmp_dept)

roles.append(tmp_role)

print(depts,roles)

邏輯挺簡單的,就是吧data中的數據分離成兩個列表。在分離過程中,用兩個字典臨時周轉一下。

但是在實際運行過程中,卻沒有得到期望的結果。得到的結果是

[{'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}, {'name': '受限用戶', 'id': '12'}]

[{'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}, {'name': '受限用戶', 'role': 'limited'}]

date中最后一條數據重復出現了。

這時意識到,應該是appen的數據有問題。懷疑是字典賦值異常。于是在append語句后查看字典id,結果發現所有的id是相同的。也就是說,插入到depts roles中的字典是同一個,即便是在迭代循環date的過程中,他的value不停地變化。

解決方法:

在每次迭代循環里,重新創建字典

代碼如下

data = [{'id': '1', 'name': '管理員', 'role': 'admin', 'desc': '系統管理員', 'acl': None},

{'id': '2', 'name': '研發', 'role': 'dev', 'desc': '研發人員', 'acl': None},

{'id': '3', 'name': '測試', 'role': 'qa', 'desc': '測試人員', 'acl': None},

{'id': '4', 'name': '項目經理', 'role': 'pm', 'desc': '項目經理', 'acl': None},

{'id': '5', 'name': '產品經理', 'role': 'po', 'desc': '產品經理', 'acl': None},

{'id': '6', 'name': '研發主管', 'role': 'td', 'desc': '研發主管', 'acl': None},

{'id': '7', 'name': '產品主管', 'role': 'pd', 'desc': '產品主管', 'acl': None},

{'id': '8', 'name': '測試主管', 'role': 'qd', 'desc': '測試主管', 'acl': None},

{'id': '9', 'name': '高層管理', 'role': 'top', 'desc': '高層管理', 'acl': None},

{'id': '10', 'name': '其他', 'role': 'others', 'desc': '其他', 'acl': None},

{'id': '11', 'name': 'guest', 'role': 'guest', 'desc': 'For guest', 'acl': None},

{'id': '12', 'name': '受限用戶', 'role': 'limited', 'desc': '受限用戶分組(只能編輯與自己相關的內容)', 'acl': None}]

depts = []

roles = []

for i in data:

tmp_dept = {}

tmp_role = {}

tmp_dept["name"] = i["name"]

tmp_dept["id"] = i["id"]

tmp_role["name"] = i["name"]

tmp_role["role"] = i["role"]

depts.append(tmp_dept)

roles.append(tmp_role)

print(depts,roles)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/271345.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/271345.shtml
英文地址,請注明出處:http://en.pswp.cn/news/271345.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

計算機網絡基礎:TCP/IP協議相關知識筆記?

1、TCP/IP特性邏輯編址:每一塊網卡會在出廠時由廠家分配了唯一的永久性物理地址。針對Internet,會為每臺連入因特網的計算機分配一個邏輯地址也就是IP地址。路由選擇:專門用于定義路由器如何選擇網絡路徑的協議,即IP數據包的路由選…

終于做出來了

1 <!doctype html>2 <html lang"en">3 <head>4 <meta charset"UTF-8">5 <title>精英大賽2號 </title>6 <meta name"Keywords" content"關鍵字">7 <meta name"Desp…

ashx連接mysql_ASP.net與SQLite數據庫通過js和ashx交互(連接和操作)

ASP.net與SQLite數據庫通過js和ashx交互(連接和操作)&#xff1a;廢話(也是思路)&#xff1a;用的是VS2010&#xff0c;打算做網站前后臺。由于不喜歡前臺語言里加些與html和css和js的其他內容&#xff0c;想實現前后臺語言的分離&#xff0c;與前后臺通過js的ajax實現交互&…

計算機網絡:九大命令!解決網絡故障新思路

一&#xff1a;ping命令ping是個使用頻率極高的實用程序&#xff0c;主要用于確定網絡的連通性。這對確定網絡是否正確連接&#xff0c;以及網絡連接的狀況十分有用。簡單的說&#xff0c;ping就是一個測試程序&#xff0c;如果ping運行正確&#xff0c;大體上就可以排除網絡訪…

webpack打包后引用cdn的js_JS逆向:Webpack打包后的代碼怎么搞?猿人學爬蟲比賽第十六題詳細題解...

實戰地址http://match.yuanrenxue.com/match/16抓包分析地址欄輸入 地址&#xff0c;按下F12并回車&#xff0c;發現數據在這里:查看cookie&#xff0c;無加密相關的字段。請求的接口倒是有個m的加密參數&#xff0c;看來這題的主要目的就是 看看m參數怎么進行加密的吧。切換 I…

計算機網絡基礎:IP基礎知識筆記

1、 IP地址概念IP是用來唯一標識主機地址。IP地址 網絡地址 主機地址(又稱&#xff1a;主機號和網絡號組成)例如IP&#xff1a;192.168.100.168 子網掩碼 255.255.255.0 對應的網絡地址和主機地址如下&#xff1a;192.168.100.168&#xff08;IP地址&#xff09; 192.168.1.…

bs架構的系統能連接mysql嗎_HTTP、BS架構

Django 底層原理快捷鍵方向鍵方向鍵本鍵如果活動選項是選項按鈕或文件則為移動焦點&#xff1b;方向鍵 Win鍵(簡稱Win鍵)使窗口全屏、最小化、靠左半邊、靠右半邊(部分版本不支持)&#xff1b;方向鍵Shift鍵將連續的文字或文件選中方向鍵(左右)Ctrl鍵 在英文單詞或中文詞語間跳…

離散卷積的計算

本文轉自&#xff1a; 離散卷積與自相關----------信號處理系列 http://www.cnblogs.com/einyboy/archive/2012/12/30/2839633.html 一、 定義 離散信號f(n),g(n)的定義如下&#xff1a; N-----為信號f(n)的長度 s(n)----為卷積結果序列,長度為len(f(n))len(g(n))-1 以3個元…

計算機網絡基礎:Internet常用服務介紹?

1、域名服務Internet中的域名地址和IP地址是等價的&#xff0c;它們之間是通過域名服務完成映射的。實際上DNS是一種分布式地址信息數據庫系統&#xff0c;服務器中包含整個數據庫的某部分信息&#xff0c;并供客戶查詢。域名系統采用客戶端/服務器模式&#xff0c;整個系統由解…

lamba

lamba /*** lamba*/Testpublic void test5() {Runnable r () -> System.out.println("hello");r.run();}Testpublic void test6() {int num 0;Runnable r new Runnable() {Overridepublic void run() {System.out.println("java");}};r.run();}

第五章 Response(JavaTM Servlet 規范3.1 )

The Response 響應 響應對象包裝了從服務器端返回到客戶端的所有信息。在HTTP協議上&#xff0c;這些信息既可以通過HTTP headers 又可以通過響應體從服務器端傳輸到客戶端。 5.1 緩沖 為了效率&#xff0c;servlet 容器允許但非必須緩沖到客戶端的輸出。典型地&#xff0c;服…

c語言深度剖析第三版pdf_入門到入墳,蘊含全網最強知識點3283頁筆記、pdf教程,活到老,學到老...

又到了“金九銀十”面試求職高峰期&#xff0c;在金三銀四時也參與過不少面試&#xff0c;2020都說工作不好找&#xff0c;也是對開發人員的要求變高。前段時間自己有整理了一些Java后端開發面試常問的高頻考點問題做成一份PDF文檔&#xff08;1000道高頻題&#xff09;&#x…

mysql 5.7.23要錢嗎_最新mysql 5.7.23安裝配置圖文教程

2018年最新mysql5.7詳細安裝與配置&#xff0c;總共分為四步&#xff0c;其中環境變量配置不是必須的。1、安裝包下載2、安裝過程3、環境變量配置4、連接測試一、官網下載mysql安裝包1.前往官網下載&#xff0c;下載鏈接為&#xff1a;2.選擇合適你電腦系統的版本進行安裝。如果…

計算機基礎:信息安全相關知識筆記

1、信息安全要素機密性&#xff1a;保證信息不暴露給未授權的用戶。完整性&#xff1a;得到允許的用戶可以修改數據&#xff0c;并且可以判斷數據是否被篡改。可用性&#xff1a;擁有授權的用戶可以在需要時訪問數據。可控性&#xff1a;可控制授權的范圍內的信息流向以及行為方…

mysql gtid ha_MySQl新特性 GTID

GTID簡介概念全局事務標識符(GTID)是創建的唯一標識符&#xff0c;并與在源(主)服務器上提交的每個事務相關聯。此標識符不但是唯一的&#xff0c;而且在給定復制設置中的所有服務器上都是唯一的。所有交易和所有GTID之間都有一對一的映射關系。GTID由source_id和transaction_i…

python gui界面 tcp_通過python實現TCP編程

偽代碼&#xff1a; ss socket() #創建服務器套接字 ss.bind() #把地址綁定到套接字上 ss.listen() #監聽連接&#xff08;最大連接數&#xff09; info_loop: #服務器無限循環 cs ss.accept() #接受客戶端連接 comm_loop: #通信循環 cs.recv()/cs.send() #對話&#xff08;接…

計算機網絡安全基礎知識筆記

1、網絡安全威脅介紹非法授權訪問&#xff1a;沒有預先經過同意&#xff0c;就使用網絡或相關的計算機資源就是非授權訪問。主要有以下幾種形式&#xff1a;身份攻擊、假冒、非法用戶進入網絡系統進行違法操作、合法用戶以未授權的方式進行操作。信息泄露丟失&#xff1a;主要是…