欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python按照l(shuí)ist中字典的某key去重的示例代碼

 更新時(shí)間:2020年10月13日 11:22:01   作者:不正經(jīng)的kimol君  
這篇文章主要介紹了python按照l(shuí)ist中字典的某key去重的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

一、需求說(shuō)明

當(dāng)我們寫(xiě)爬蟲(chóng)的時(shí)候,經(jīng)常會(huì)遇到j(luò)son格式的數(shù)據(jù),它通常是如下結(jié)構(gòu):

data = [{'name':'小K','score':100},
    {'name':'小J','score':98},
    {'name':'小Q','score':95},
    {'name':'小K','score':100}]

很顯然名字為小K的數(shù)據(jù)重復(fù)了,我們需要進(jìn)行去重。通常對(duì)于list的去重,我們可以用set()函數(shù),即:

data = list(set(data))

然而,運(yùn)行之后你會(huì)發(fā)現(xiàn)它報(bào)錯(cuò)了:


list里的數(shù)據(jù)不能是dict類型,那么該怎么辦呢?

二、我的解決方案

定義一個(gè)去重的函數(shù)即可,根據(jù)里面的某個(gè)key,對(duì)數(shù)據(jù)進(jìn)行篩選去重:

def DelRepeat(data,key):
  new_data = [] # 用于存儲(chǔ)去重后的list
  values = []  # 用于存儲(chǔ)當(dāng)前已有的值
  for d in data:
    if d[key] not in values:
      new_data.append(d)
      values.append(d[key])
  return new_data

參數(shù)data為需要去重的list,key為去重的?。窗凑漳膫€(gè)key來(lái)去重),去重后結(jié)果為:

[{'name': '小K', 'score': 100},
 {'name': '小J', 'score': 98},
 {'name': '小Q', 'score': 95}]

成功去重!

到此這篇關(guān)于python按照l(shuí)ist中字典的某key去重的示例代碼的文章就介紹到這了,更多相關(guān)python list字典的某key去重內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

最新評(píng)論