如何在NumPy中连接两个一维数组?

时间:2017-03-20 17:07:16

标签: python numpy matrix multidimensional-array numpy-ndarray

我有两个数组A = [a1, ..., an]B = [b1, ..., bn]。 我想获得等于

的新矩阵C.
[[a1, b1],
 [a2, b2],
 ...
 [an, bn]]

如何使用numpy.concatenate

进行操作

3 个答案:

答案 0 :(得分:3)

这个非常简单但最快的解决方案怎么样?

In [73]: a = np.array([0, 1, 2, 3, 4, 5])
In [74]: b = np.array([1, 2, 3, 4, 5, 6])
In [75]: ab = np.array([a, b])
In [76]: c = ab.T

In [77]: c
Out[77]: 
array([[0, 1],
       [1, 2],
       [2, 3],
       [3, 4],
       [4, 5],
       [5, 6]])

但是,正如Divakar pointed out一样,使用np.column_stack会直接给出答案:

In [85]: np.column_stack([a, b])
Out[85]: 
array([[0, 1],
       [1, 2],
       [2, 3],
       [3, 4],
       [4, 5],
       [5, 6]])

效率(按降序排列)

有趣的是,我的简单解决方案最快。 (比np.concatenate快一点,速度是np.column_stack的两倍,速度是np.vstack的三倍

In [86]: %timeit np.array([a, b]).T
100000 loops, best of 3: 4.44 µs per loop

In [87]: %timeit np.concatenate((a[:,None], b[:,None]), axis=1)
100000 loops, best of 3: 5.6 µs per loop

In [88]: %timeit np.column_stack([a, b])
100000 loops, best of 3: 9.5 µs per loop

In [89]: %timeit np.vstack((a, b)).T
100000 loops, best of 3: 14.7 µs per loop

答案 1 :(得分:2)

你也可以使用np.vstack然后在

之后转置矩阵
import numpy as np
A = [1, 2, 3]
B = [4, 5, 6]
C = np.vstack((A, B)).T

答案 2 :(得分:0)

In [26]: A=np.arange(5)
In [27]: B=np.arange(10,15)
In [28]: np.concatenate((A[:,None], B[:,None]), axis=1)
Out[28]: 
array([[ 0, 10],
       [ 1, 11],
       [ 2, 12],
       [ 3, 13],
       [ 4, 14]])
In [29]: _.tolist()
Out[29]: [[0, 10], [1, 11], [2, 12], [3, 13], [4, 14]]

np.column_stacknp.vstacknp.stack都做同样的事情,只是以不同的方式扩展数组的维度。

np.stack((A,B),-1)像我一样使用newaxis索引扩展数组。

np.column_stack((A,B))使用:

arr = array(arr, copy=False, subok=True, ndmin=2).T

np.vstack((A,B)).T使用:

concatenate([atleast_2d(_m) for _m in tup], 0)

出于好奇,请注意这个vstack等价物:

In [38]: np.concatenate((A[None],B[None]))
Out[38]: 
array([[ 0,  1,  2,  3,  4],
       [10, 11, 12, 13, 14]])