您可以使用itertools.groupby:
from itertools import groupby
from operator import itemgetter
from pprint import pprint
data = [ {
'Organization' : '123 Solar',
'Phone' : '444-444-4444',
'Email' : '',
'website' : 'www.123solar.com'
}, {
'Organization' : '123 Solar',
'Phone' : '',
'Email' : '[email protected]',
'Website' : 'www.123solar.com'
},
{
'Organization' : '234 test',
'Phone' : '111',
'Email' : '[email protected]',
'Website' : 'b.123solar.com'
},
{
'Organization' : '234 test',
'Phone' : '222',
'Email' : '[email protected]',
'Website' : 'bd.123solar.com'
}]
data = sorted(data, key=itemgetter('Organization'))
result = {}
for key, group in groupby(data, key=itemgetter('Organization')):
result[key] = [item for item in group]
pprint(result)
打印:
{'123 Solar': [{'Email': '',
'Organization': '123 Solar',
'Phone': '444-444-4444',
'website': 'www.123solar.com'},
{'Email': '[email protected]',
'Organization': '123 Solar',
'Phone': '',
'Website': 'www.123solar.com'}],
'234 test': [{'Email': '[email protected]',
'Organization': '234 test',
'Phone': '111',
'Website': 'b.123solar.com'},
{'Email': '[email protected]',
'Organization': '234 test',
'Phone': '222',
'Website': 'bd.123solar.com'}]}
UPD:
這裏是你可以做的到組什麼商品成單字代碼:
for key, group in groupby(data, key=itemgetter('Organization')):
result[key] = {'Phone': [],
'Email': [],
'Website': []}
for item in group:
result[key]['Phone'].append(item['Phone'])
result[key]['Email'].append(item['Email'])
result[key]['Website'].append(item['Website'])
然後,在result
你必須:
{'123 Solar': {'Email': ['', '[email protected]'],
'Phone': ['444-444-4444', ''],
'Website': ['www.123solar.com', 'www.123solar.com']},
'234 test': {'Email': ['[email protected]', '[email protected]'],
'Phone': ['111', '222'],
'Website': ['b.123solar.com', 'bd.123solar.com']}}
我測試了你的代碼,它不完全是我所需要的。謝謝你給我看這種感覺,真是太棒了。我正在尋找一種方法將具有相同組織名稱的所有字典合併到同一個列表中的一個字典中。 –
當然,你可以從這一個字典。只需使用那個'group'變量即可。 – alecxe
@ Jacob-IT,我已經更新了答案,請檢查。 – alecxe