numpy.concat#

numpy.concat((a1, a2, ...), axis=0, out=None, dtype=None, casting="same_kind")#

沿着现有轴连接一系列数组。

参数:
a1, a2, …array_like 序列

这些数组必须具有相同的形状,除了对应于axis(默认为第一个)的维度。

axisint,可选

将要连接数组的轴。如果 axis 为 None,则在使用前将数组展平。默认为 0。

outndarray,可选

如果提供,则为放置结果的目标位置。形状必须正确,与如果没有指定 out 参数则 concatenate 将返回的形状匹配。

dtypestr 或 dtype

如果提供,则目标数组将具有此 dtype。不能与out一起提供。

版本 1.20.0 中的新功能。

casting{'no', 'equiv', 'safe', 'same_kind', 'unsafe'},可选

控制可能发生哪种数据转换。默认为 'same_kind'。有关选项的说明,请参见 casting

版本 1.20.0 中的新功能。

返回:
resndarray

连接后的数组。

另请参见

ma.concatenate

保留输入掩码的连接函数。

array_split

将数组分割成多个大小相等或接近相等的小数组。

split

将数组分割成多个大小相等的小数组列表。

hsplit

水平(列方向)分割数组成多个子数组。

vsplit

垂直(行方向)分割数组成多个子数组。

dsplit

沿第三轴(深度)分割数组成多个子数组。

stack

沿着新轴堆叠一系列数组。

block

从块组装数组。

hstack

水平(列方向)顺序堆叠数组。

vstack

垂直(行方向)顺序堆叠数组。

dstack

深度方向(沿第三维度)顺序堆叠数组。

column_stack

将一维数组作为列堆叠到二维数组中。

备注

当要连接的一个或多个数组是 MaskedArray 时,此函数将返回 MaskedArray 对象而不是 ndarray,但不会保留输入掩码。在预期 MaskedArray 作为输入的情况下,请改用掩码数组模块中的 ma.concatenate 函数。

示例

>>> import numpy as np
>>> a = np.array([[1, 2], [3, 4]])
>>> b = np.array([[5, 6]])
>>> np.concatenate((a, b), axis=0)
array([[1, 2],
       [3, 4],
       [5, 6]])
>>> np.concatenate((a, b.T), axis=1)
array([[1, 2, 5],
       [3, 4, 6]])
>>> np.concatenate((a, b), axis=None)
array([1, 2, 3, 4, 5, 6])

此函数不会保留 MaskedArray 输入的掩码。

>>> a = np.ma.arange(3)
>>> a[1] = np.ma.masked
>>> b = np.arange(2, 5)
>>> a
masked_array(data=[0, --, 2],
             mask=[False,  True, False],
       fill_value=999999)
>>> b
array([2, 3, 4])
>>> np.concatenate([a, b])
masked_array(data=[0, 1, 2, 2, 3, 4],
             mask=False,
       fill_value=999999)
>>> np.ma.concatenate([a, b])
masked_array(data=[0, --, 2, 2, 3, 4],
             mask=[False,  True, False, False, False, False],
       fill_value=999999)