如何解决在Python中按重复排序列表
| 我有一个包含多个重复项的列表。我正在尝试通过给重复次数最多的项目排序来对列表进行排序。 所以它会变成这个[\'a\',\'b\',\'c\',\'a\',\'d\']
进入这个
[\'a\',\'d\']
解决方法
>>> from collections import Counter
>>> [k for k,v in Counter([\'a\',\'b\',\'c\',\'a\',\'d\']).most_common() for i in xrange(v)]
[\'a\',\'d\']
这可能更容易理解
>>> counter = Counter([\'a\',\'d\'])
>>> sorted(counter.elements(),key=counter.get,reverse=True)
[\'a\',\'d\']
, d = {}
for a in l:
d[a] += d.setdefault(a,0)
l.sort(key = lambda k: (d[k],k),reverse = True)
, [v for (v,c) in sorted(((x,list(y)) for (x,y) in
itertools.groupby(sorted([\'a\',\'d\']))),key=lambda x: len(x[1]),reverse=True) for z in c]
编辑:
现在以sum()
!
sum((c for (v,reverse=True)),[])
, l = [\'a\',\'d\']
sorted_list = [item for item in sorted(l,key=lambda x: l.count(x),reverse=True)]
尽管这是一个简单的解决方案,但是请注意使用大列表时对每个元素进行计数的复杂性。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。