Home >Backend Development >Python Tutorial >Python list deduplication

Python list deduplication

巴扎黑
巴扎黑Original
2016-12-07 10:46:031661browse

Python list list deduplication

一.{}.fromkeys(list).keys()

list2 = {}.fromkeys(list1).keys()

二.set

list2 = list (set(list1))

三.itertools.grouby

ids = [1,4,3,3,4,2,3,4,5,6,1]

ids.sort()

it = itertools.groupby(ids)

for k, g in it:

print k

Four, stupid method

ids = [1,2,3,3,4,2,3,4 ,5,6,1]

news_ids = []

for id in ids:

if id not in news_ids:

news_ids.append(id)

print news_ids

These four have their own characteristics, After deduplication, the sorting of elements has changed. It is said that the first method is faster than the second one

5. Index sorting again can remove duplication and maintain the order of elements

#The result is [1, 4, 3, 2, 5, 6] Don’t [1, 2, 3, 4, 5, 6]

ids = [1,4,3,3,4,2,3,4,5,6,1]

news_ids = list(set(ids))

news_ids.sort(key=ids.index)

print news_ids #[1, 4, 3, 2, 5, 6]

Six: Reduce

ids = [ 1,4,3,3,4,2,3,4,5,6,1]

func = lambda x,y:x if y in x else x + [y]

print reduce(func, [ [], ] + ids)#[1, 4, 3, 2, 5, 6]


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn