串列中元素位置的索參考的是L.index
本文實體講述了Python去除串列中重復元素的方法,分享給大家供大家參考,具體如下:
比較容易記憶的是用內置的set
l1 = ['b','c','d','b','c','a','a']
l2 = list(set(l1))
print (l2)
還有一種據說速度更快的,沒測驗過兩者的速度差別
l1 = ['b','c','d','b','c','a','a']
l2 = {}.fromkeys(l1).keys()
print (l2)
這兩種都有個缺點,祛除重復元素后排序變了:
['a', 'c', 'b', 'd']
如果想要保持他們原來的排序:
用list類的sort方法
l1 = ['b','c','d','b','c','a','a']
l2 = list(set(l1))
l2.sort(key=l1.index)
print (l2)
也可以這樣寫
#Python學習交流群:711312441
l1 = ['b','c','d','b','c','a','a']
l2 = sorted(set(l1),key=l1.index)
print (l2)
也可以用遍歷
l1 = ['b','c','d','b','c','a','a']
l2 = []
for i in l1:
if not i in l2:
l2.append(i)
print (l2)
上面的代碼也可以這樣寫
l1 = ['b','c','d','b','c','a','a']
l2 = []
[l2.append(i) for i in l1 if not i in l2]
print (l2)
這樣就可以保證排序不變了
在pythoncook里邊提到的一種面向可哈希資料的取出相同元素的方法是:利用到了集合與生成器set、yield
def dedupe(items):
seen = set()
for item in items:
if item not in seen:
yield item
seen.add(item)
不可變型別可哈希,可變型別不可哈希,對于不可哈希的資料
上述代碼改成:
def dedupe(items, key=None):
seen = set()
for item in items:
val = item if key is None else key(item)
if val not in seen:
yield item
seen.add(val)
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/531908.html
標籤:其他
上一篇:SpringBoot(二):創建SpringBoot專案的方式
下一篇:[C++] - GCC和LLVM對方法 warning: non-void function does not return a value [-Wreturn-type] 的處理差異
