亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

從元組列表中刪除部分重復的元組

從元組列表中刪除部分重復的元組

慕標琳琳 2021-10-19 09:50:40
我有一個元組列表,如果它的第一個項目與列表中其他元組的第一個項目匹配,則需要刪除元組。第 3 項可能相同也可能不同,所以我不能使用 set(我已經看到這個問題 - Grab unique tuples in python list,不管順序如何,這與我的問題不同)例如,如果我得到a:[(0, 13, 'order1'), (14, 27, 'order2'), (14, 27, 'order2.1'),  (0, 13, 'order1'), (28, 41, 'order3')]我希望輸出為:[(14, 27, 'order2'), (0, 13, 'order1'), (28, 41, 'order3')]我使用以下代碼獲得所需的輸出。for e, i in enumerate(a):    r = [True if i[0] == k[0] and e != j else False for j, k in enumerate(a)]    if any(r):        a.pop(e)pprint(a)有沒有更好或更pythonic的方法來實現相同的目標?
查看完整描述

3 回答

?
慕仙森

TA貢獻1827條經驗 獲得超8個贊

通常的方法是從你想要重復數據刪除的任何內容中鍵入一個字典,例如:


>>> a = [(0, 13, 'order1'), (14, 27, 'order2'), (14, 27, 'order2.1'), (0, 13, 'order1'), (28, 41, 'order3')] 

>>> print(*{tup[:2]: tup for tup in a}.values()) 

(0, 13, 'order1') (14, 27, 'order2.1') (28, 41, 'order3')

這是O(n)時間復雜度,優于基于O(n log n) groupby 的方法。


查看完整回答
反對 回復 2021-10-19
?
www說

TA貢獻1775條經驗 獲得超8個贊

您可以在分組的排序列表中獲取每個組的第一個元素:


from itertools import groupby

from operator import itemgetter


a = [(0, 13, 'order1'), (14, 27, 'order2'), (14, 27, 'order2.1'), (0, 13, 'order1'), (28, 41, 'order3')]


result = [list(g)[0] for k, g in groupby(sorted(a), key=itemgetter(0))]

print(result)


查看完整回答
反對 回復 2021-10-19
?
MYYA

TA貢獻1868條經驗 獲得超4個贊

您應該避免在迭代列表時就地修改列表。相反,您可以使用流行的itertools unique_everseen食譜,也可以在 3rd party 中使用more_itertools。只需operator.itemgetter在key參數中使用:


from more_itertools import unique_everseen

from operator import itemgetter


res = list(unique_everseen(L, key=itemgetter(0, 1)))

該解決方案需要O(?)時間,但一般是少比基于字典的溶液有效,盡管它是在它的意圖可以說是更清晰。


查看完整回答
反對 回復 2021-10-19
  • 3 回答
  • 0 關注
  • 331 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號