根据另一个列表中的值对列表进行排序

新手上路,请多包涵

我有一个这样的字符串列表:

 X = ["a", "b", "c", "d", "e", "f", "g", "h", "i"]
Y = [ 0,   1,   1,   0,   1,   2,   2,   0,   1 ]

使用 Y 的值对 X 进行排序以获得以下输出的最短方法是什么?

 ["a", "d", "h", "b", "c", "e", "i", "f", "g"]

具有相同“键”的元素的顺序无关紧要。我可以使用 for 构造,但我很好奇是否有更短的方法。有什么建议么?

原文由 Legend 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 757
2 个回答

最短代码

[x for _, x in sorted(zip(Y, X))]

例子:

 X = ["a", "b", "c", "d", "e", "f", "g", "h", "i"]
Y = [ 0,   1,   1,    0,   1,   2,   2,   0,   1]

Z = [x for _,x in sorted(zip(Y,X))]
print(Z)  # ["a", "d", "h", "b", "c", "e", "i", "f", "g"]


一般来说

[x for _, x in sorted(zip(Y, X), key=lambda pair: pair[0])]

解释:

  1. zip 两个 list s。
  2. 创建一个新的,排序的 list 基于 zip 使用 sorted()
  3. 使用列表推导式从已排序、压缩的 list提取 每对的第一个元素。

有关如何设置\使用 key 参数以及 sorted 函数的更多信息,请查看


原文由 Whatang 发布,翻译遵循 CC BY-SA 4.0 许可协议

将两个列表压缩在一起,对其进行排序,然后取出您想要的部分:

 >>> yx = zip(Y, X)
>>> yx
[(0, 'a'), (1, 'b'), (1, 'c'), (0, 'd'), (1, 'e'), (2, 'f'), (2, 'g'), (0, 'h'), (1, 'i')]
>>> yx.sort()
>>> yx
[(0, 'a'), (0, 'd'), (0, 'h'), (1, 'b'), (1, 'c'), (1, 'e'), (1, 'i'), (2, 'f'), (2, 'g')]
>>> x_sorted = [x for y, x in yx]
>>> x_sorted
['a', 'd', 'h', 'b', 'c', 'e', 'i', 'f', 'g']

将这些组合在一起得到:

 [x for y, x in sorted(zip(Y, X))]

原文由 Ned Batchelder 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题