Python 如何使用lambda对元组排序
我有一个元组坐标:Python 如何使用lambda对元组排序,python,sorting,lambda,Python,Sorting,Lambda,我有一个元组坐标: [(1, 2), (3, 2), (1, 4)] 我还有一个合作伙伴:(8,7) 现在我需要根据元组中每个点与单个点之间的距离对上面的元组进行排序。 如何使用sorted()?基本上,您可以计算点pt和列表中每个元组之间的欧氏距离。该函数可以做到这一点,尽管如果您想自己实现它,这将是微不足道的 >>> from numpy import hypot >>> l = [(1, 2), (3, 2), (1, 4)] >>>
[(1, 2), (3, 2), (1, 4)]
我还有一个合作伙伴:(8,7)
现在我需要根据元组中每个点与单个点之间的距离对上面的元组进行排序。如何使用
sorted()
?基本上,您可以计算点pt
和列表中每个元组之间的欧氏距离。该函数可以做到这一点,尽管如果您想自己实现它,这将是微不足道的
>>> from numpy import hypot
>>> l = [(1, 2), (3, 2), (1, 4)]
>>> pt = [8,7]
>>> sorted(l, key = lambda i: hypot(i[0]-pt[0], i[1]-pt[1]))
[(3, 2), (1, 4), (1, 2)]
如果您不想使用numpy并想用纯Python完成它
>>> array = [(1, 2), (3, 2), (1, 4)]
>>> point = [8, 7]
>>> array.sort(key = lambda k: (k[0] - point[0])**2 + (k[1] - point[1])**2)
>>> array
[(3, 2), (1, 4), (1, 2)]
您可以(ab)使用complex
类型来避免任何其他导入<代码>排序(l,键=λx:abs(复数(*x)-复数(*pt))。