一、基礎使用
1、用Python自帶的set函數實現列表取交集
a = [1, 2, 3, 4, 5] b = [3, 4, 5, 6, 7] c = set(a) & set(b) print(list(c)) # 返回結果為 [3, 4, 5]
2、用Python自帶的intersection函數實現列表取交集
a = [1, 2, 3, 4, 5] b = [3, 4, 5, 6, 7] c = list(set(a).intersection(set(b))) print(c) # 返回結果為 [3, 4, 5]
3、用Python自帶的filter函數實現列表取交集
a = [1, 2, 3, 4, 5] b = [3, 4, 5, 6, 7] c = list(filter(lambda x: x in a, b)) print(c) # 返回結果為 [3, 4, 5]
二、列表裡嵌套列表
1、普通的嵌套列表
a = [[1, 2], [2, 3], [3, 4]] b = [[2, 3], [3, 4], [4, 5]] c = list(filter(lambda x: x in a, b)) print(c) # 返回結果為 [[2, 3], [3, 4]]
2、列表裡元素也是列表
a = [[[1, 2], [2, 3]], [[3, 4], [4, 5]], [[5, 6], [6, 7]]] b = [[[2, 3], [3, 4]], [[4, 5], [5, 6]], [[6, 7], [7, 8]]] c = [] for i in a: for j in b: if i == j: c.append(i) print(c) # 返回結果為 [[[2, 3], [3, 4]], [[6, 7], [7, 8]]]
三、字典類型中取交集
1、字典類型的鍵值相交
a = {'a': 1, 'b': 2, 'c': 3} b = {'b': 4, 'c': 3, 'd': 5} c = list(a.keys() & b.keys()) print(c) # 返回結果為 ['c', 'b']
2、字典類型的值相交
a = {'a': 1, 'b': 2, 'c': 3} b = {'d': 5, 'e': 3, 'f': 2} c = list(set(a.values()).intersection(set(b.values()))) print(c) # 返回結果為 [2, 3]
四、保留重複元素
1、用Counter函數統計交集元素出現的次數
from collections import Counter a = [1, 2, 2, 3, 4] b = [2, 2, 3, 3, 5] c = list((Counter(a) & Counter(b)).elements()) print(c) # 返回結果為 [2, 2, 3]
2、用set集合替換Counter函數,實現更高效的操作
a = [1, 2, 2, 3, 4] b = [2, 2, 3, 3, 5] c = list((set(a) & set(b))) print(c) # 返回結果為 [2, 3]
五、不同數據類型之間取交集
1、列表與集合取交集
a = [1, 2, 3, 4, 5] b = {3, 4, 5, 6, 7} c = list(set(a).intersection(b)) print(c) # 返回結果為 [3, 4, 5]
2、字元串與列表取交集
a = 'abcdefghijklmnopqrstuvwxyz' b = ['a', 'e', 'i', 'o', 'u'] c = list(set(a).intersection(b)) print(c) # 返回結果為 ['a', 'e', 'i', 'o', 'u']
以上就是List取交集的多個方面詳解。
原創文章,作者:SKFOR,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/332480.html