Python中字典列表中删除重复项
要從字典列表中刪除重復項:
- 使用字典推導來遍歷列表。
- 使用每個 id 屬性的值作為鍵,使用字典作為值。
- 使用
dict.values()方法只獲取唯一的字典。 - 使用
list()類將結(jié)果轉(zhuǎn)換為列表。
list_of_dictionaries = [
{'id': 1, 'site': 'jiyik.com'},
{'id': 2, 'site': 'google.com'},
{'id': 1, 'site': 'jiyik.com'},
]
result = list(
{
dictionary['id']: dictionary
for dictionary in list_of_dictionaries
}.values()
)
# ??? [{'id': 1, 'site': 'jiyik.com'}, {'id': 2, 'site': 'google.com'}]
print(result)
我們使用字典理解來遍歷字典列表。
字典理解與列表理解非常相似。
他們對字典中的每個鍵值對執(zhí)行一些操作,或者選擇滿足條件的鍵值對的子集。
在每次迭代中,我們將當前 id 的值設置為鍵,將實際字典設置為值。
字典中的鍵是唯一的,因此任何重復的值都會被刪除。
然后我們使用 dict.values() 方法只返回唯一的字典。
dict.values方法返回字典值的新視圖。
my_dict = {'id': 1, 'name': 'jiyik'}
print(my_dict.values()) # ??? dict_values([1, 'jiyik'])
最后一步是使用 list() 類將視圖對象轉(zhuǎn)換為包含唯一字典的列表。
列表類接受一個可迭代對象并返回一個列表對象。
或者,我們可以使用 for 循環(huán)。
使用 for 循環(huán)從字典列表中刪除重復項
要從字典列表中刪除重復項:
- 聲明一個存儲空列表的新變量。
- 使用
for循環(huán)遍歷字典列表。 - 使用
list.append()方法將非重復字典添加到新列表中。
list_of_dictionaries = [
{'id': 1, 'site': 'jiyik.com'},
{'id': 2, 'site': 'google.com'},
{'id': 1, 'site': 'jiyik.com'},
]
new_list = []
for dictionary in list_of_dictionaries:
if dictionary not in new_list:
new_list.append(dictionary)
# ??? [{'id': 1, 'site': 'jiyik.com'}, {'id': 2, 'site': 'google.com'}]
print(new_list)
我們使用 for 循環(huán)遍歷字典列表。
在每次迭代中,我們使用
not in運算符來檢查字典是否不存在于新列表中。
如果滿足條件,我們使用 list.append() 方法將字典附加到列表中。
in 運算符測試成員資格。 例如,如果 x 是 l 的成員,則 x in l 的計算結(jié)果為 True,否則,它的計算結(jié)果為 False。
x not in l返回 x in l 的否定。
list.append() 方法將一個項目添加到列表的末尾。
my_list = ['fql', 'jiyik']
my_list.append('com')
print(my_list) # ??? ['fql', 'jiyik', 'com']
到此這篇關于Python中字典列表中刪除重復項的文章就介紹到這了,更多相關Python字典刪除重復項內(nèi)容請搜索電腦知識網(wǎng)www.pcxun.com以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持電腦知識網(wǎng)www.pcxun.com!
總結(jié)
以上是生活随笔為你收集整理的Python中字典列表中删除重复项的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 延安颂是谁画的啊?
- 下一篇: Pandas中DataFrame的常用用