python - 合并多列表組成一個字典
問題描述
我把原始問題簡化一下,希望各位大大幫忙
有2個等長list:idlist = [id1,id2,id3,id4,id5]userlist = [name1,name2,name3,name4,name5]
希望合并成以下形式的字典:
dict_user = {{’id’:id1, ’name’:name1},{’id’:id2, ’name’:name2},{’id’:id3, ’name’:name3},{’id’:id4, ’name’:name4},{’id’:id5, ’name’:name5}}
怎么生成以上字典呢?
補充:python 3
問題解答
回答1:首先你的dict_user看起來并不是字典,但是其中每一個元素是字典可以用zip函數(shù)合并兩個等長度的list成為二維list,在python3中idlist = [id1,id2,id3,id4,id5]userlist = [name1,name2,name3,name4,name5]zipped= zip(idlist, userlist)user= [dict(id=id,name=name) for id ,name in list(zipped)]可以得到user = [{’id’:id1, ’name’:name1},{’id’:id2, ’name’:name2},{’id’:id3, ’name’:name3},{’id’:id4, ’name’:name4},{’id’:id5, ’name’:name5}]
回答2:for方式
var listObj={},dict_user=[];for(var i=0,len=idlist.length;i<len;i++){ listObj.id=idlist[i] listObj.name=userlist[i] dict_user.push(listObj);}
foeEach
var listObj={},dict_user=[];idlist.forEach(function(item,index,self){ listObj.id=item;//listObj.id=idlist[index]; listObj.name=userlist[index]; dict_user.push(listObj);})忽略吧!我看錯了!回答3:
首先dict_user = { ... } 這種形式應(yīng)該是 集合(set/frozenset),但是這兩個都要求存儲的對象是hashable,也就是不可以為 dict 這種可變對象,所以不存在上面這種形式的。
回答4:應(yīng)該是dict_user = [{’id’:id1, ’name’:name1},{’id’:id2, ’name’:name2},{’id’:id3, ’name’:name3},{’id’:id4, ’name’:name4},{’id’:id5, ’name’:name5}]吧,如果是這樣,代碼如下:
dict_user = [{'id': id, 'name': user} for id, user in zip(idlist, userlist)]
相關(guān)文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 數(shù)據(jù)庫表中,兩個表互為外鍵參考如何解決3. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現(xiàn)存在即更新應(yīng)該使用哪個標(biāo)簽?4. mysql - 數(shù)據(jù)庫建字段,默認(rèn)值空和empty string有什么區(qū)別 1105. mysql儲存json錯誤6. sql語句 - 如何在mysql中批量添加用戶?7. mysql - 表名稱前綴到底有啥用?8. php - 公眾號文章底部的小程序二維碼如何統(tǒng)計?9. Navicat for mysql 中以json格式儲存的數(shù)據(jù)存在大量反斜杠,如何去除?10. mysql - 怎么生成這個sql表?
