刪除列表中的重復項幾乎我需要編寫一個程序來檢查列表是否有任何重復項,如果有,它會刪除它們并返回一個新列表,其中包含未復制/刪除的項目。這就是我所擁有的,但說實話,我不知道該怎么做。def remove_duplicates():
t = ['a', 'b', 'c', 'd']
t2 = ['a', 'c', 'd']
for t in t2:
t.append(t.remove())
return t
3 回答

波斯汪
TA貢獻1811條經驗 獲得超4個贊
在Python 2.7中,從迭代中刪除重復項同時保持原始順序的新方法是:
>>> from collections import OrderedDict
>>> list(OrderedDict.fromkeys('abracadabra'))
['a', 'b', 'r', 'c', 'd']
在Python 3.5中,OrderedDict有一個C實現。我的時間表明,現在這是Python 3.5的各種方法中最快和最短的。
在Python 3.6中,常規字典變得有序且緊湊。(此功能適用于CPython和PyPy,但在其他實現中可能不存在)。這為我們提供了一種新的最快的扣除方式,同時保留了訂單:
>>> list(dict.fromkeys('abracadabra'))
['a', 'b', 'r', 'c', 'd']
在Python 3.7中,保證常規字典在所有實現中都有序。 因此,最短和最快的解決方案是:
>>> list(dict.fromkeys('abracadabra'))
['a', 'b', 'r', 'c', 'd']
添加回答
舉報
0/150
提交
取消