实现一个函数的最佳方法是什么,该函数接受任意数量的1d数组并返回包含匹配值索引(如果有)的元组.
这是我想要做的一些伪代码:
a = np.array([1, 0, 4, 3, 2])
b = np.array([1, 2, 3, 4, 5])
c = np.array([4, 2])
(ind_a, ind_b, ind_c) = return_equals(a, b, c)
# ind_a = [2, 4]
# ind_b = [1, 3]
# ind_c = [0, 1]
(ind_a, ind_b, ind_c) = return_equals(a, b, c, sorted_by=a)
# ind_a = [2, 4]
# ind_b = [3, 1]
# ind_c = [0, 1]
def return_equals(*args, sorted_by=None):
...
解决方法:
您可以将numpy.intersect1d与reduce一起使用:
def return_equals(*arrays):
matched = reduce(np.intersect1d, arrays)
return np.array([np.where(np.in1d(array, matched))[0] for array in arrays])
这里减少可能有点慢,因为我们在这里创建中间NumPy数组(对于大量输入它可能非常慢),如果我们使用Python的set及其.intersection()方法,我们可以阻止这种情况:
matched = np.array(list(set(arrays[0]).intersection(*arrays[1:])))
标签:python,arrays,sorting,indexing,numpy
来源: https://codeday.me/bug/20190519/1137625.html