[英]How to write this list comprehension correctly?
我正在嘗試編寫一個列表理解來整理不重復的字典。 我正在處理的數據如下所示:
[
{
'username': 'food_lovers_mad',
'data': (some unique data)
},
{
'username': 'oceanarmor',
'data': (some unique data)
},
{
'username': 'freediverlife',
'data': (some unique data)
}
]
我正在整理具有相同用戶名的字典並將它們添加到新列表中。 這是我目前的方法:
duplicates = [dup for outer in array for dup in
[inner for inner in array
if outer['username'] == inner['username']]]
編輯:輸入的一個例子可能是:
[
{
'username': 'duplicate',
'data': {
"watches": 1241,
"followers": 71234
}
},
{
'username': 'duplicate',
'data': {
"watches": 12431,
"followers": 151
}
},
{
'username': 'not duplicate',
'data': {
"watches": 2124,
"followers": 54124
}
}
]
這將產生輸出:
[
{
'username': 'duplicate',
'data': {
"watches": 1241,
"followers": 71234
}
},
{
'username': 'not duplicate',
'data': {
"watches": 2124,
"followers": 54124
}
}
]
我真的很困惑,因為我對 python 中的列表理解有點陌生,所以我很感激任何幫助!
您可以使用集合來識別重復項:
seen = set()
duplicates = [d for d in array if d["username"] in seen or seen.add(d["username"])]
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.