collections.Counter
делает это быстро и тривиально:
from collections import Counter
# Using other answer's listOfGenes for convenience
listOfGenes = "RGN RBM10 ARAF ZNF630 FTSJ1 SLC35A2 SLC35A2 SLC35A2 MAGIX DGKK XAGE1B XAGE1B SMC1A FAM120C CXorf49 CXorf49B CHIC1 ABCB7 PBDC1 FGF16 ATP7A CYLC1 TSPAN6 BTK BTK TCEAL4 TEX13A FRMPD3 PRPS1 COL4A6 COL4A6 COL4A6".split()
# Actual work is a one-liner; count them all, keep those with count of 2 or more
duplicates = [gene for gene, cnt in Counter(listOfGenes).items() if cnt >= 2]
В CPython 3.6 и более поздних версиях (и во всех интерпретаторах Python, когда они достигают 3.7) обеспечивается порядок вставки dict
с, duplicates
list
будет упорядочено в порядке первого появления в listOfGenes
; на 3.5 и ранее, он будет иметь произвольный порядок.