两个不对等列表,如何按照另一个顺序排序?

list_1 = [3, 4, 6, 0]
base_list = [6, 5, 3, 4, 8, 7, 0]

如果希望list_1里面的值,按照base_list中的顺序排序,如何做比较快

list_1的最终输出期望是: [6, 3, 4, 0]


回答:

写了两种,各循环了一百万次,但时间上没差多少。

你可以自己比较一下原始数组更多的情况下。

两个不对等列表,如何按照另一个顺序排序?

# 第一种

list_2 = [i for i in base_list if i in list_1]

# 第二种

map = dict(zip(base_list, count()))

list_3 = sorted(list_1, key=lambda i: map[i])

P.S. 也有库专门干这种活儿的,比如 more_itertools 啥的,想用的话看文档。

以上是 两个不对等列表,如何按照另一个顺序排序? 的全部内容, 来源链接: utcz.com/p/938582.html

回到顶部