[英]Sort a list in python based on another sorted list
我想基于预先排序的列表在Python中对列表进行排序
presorted_list = ['2C','3C','4C','2D','3D','4D']
unsorted_list = ['3D','2C','4D','2D']
有没有办法对列表进行排序以反映预先排序的列表,尽管事实并非排序列表中不存在所有元素?
我希望结果看起来像这样:
after_sort = ['2C','2D','3D','4D']
谢谢!
In [5]: sorted(unsorted_list, key=presorted_list.index)
Out[5]: ['2C', '2D', '3D', '4D']
或者,为了获得更好的性能(特别是当len(presorted_list)
很大时),
In [6]: order = {item:i for i, item in enumerate(presorted_list)}
In [7]: sorted(unsorted_list, key=order.__getitem__)
Out[7]: ['2C', '2D', '3D', '4D']
有关如何使用key
进行排序的更多信息,请参阅优秀的Howto Sort wiki 。
如果unsorted_list
包含不在presorted_list
中的项(例如'6D'
),则上述方法将引发错误。 首先,您必须决定如何对这些项目进行排序。 如果您希望将它们放在列表的末尾,则可以使用
In [10]: unsorted_list = ['3D','2C','6D','4D','2D']
In [11]: sorted(unsorted_list, key=lambda x: order.get(x, float('inf')))
Out[11]: ['2C', '2D', '3D', '4D', '6D']
或者如果您希望将这些项目放在列表的前面,请使用
In [12]: sorted(unsorted_list, key=lambda x: order.get(x, -1))
Out[12]: ['6D', '2C', '2D', '3D', '4D']
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.