在numpy中以二维数组的特定位置插入一列?

时间:2016-11-27 05:10:40

标签: python arrays numpy insertion

我有一个2D numpy数组,我需要在第一列之前添加一列作为id。

我的阵列是这样的:

x = [['8' '4' 'M' '55' '7' 'S' '7' '2']
 ['36' '4' 'F' '58' '1' 'M' '7' '7']
 ['33' '3' 'M' '34' '4' 'M' '2' '3']
 ['43' '1' 'F' '64' '4' 'M' '7' '68']
 ['1' '2' 'M' '87' '4' 'M' '7' '1']]

我要添加的列是y = ['1' '2' '3' '4' '5']

目标输出为:

z = [['1' '8' '4' 'M' '55' '7' 'S' '7' '2']
 ['2' '36' '4' 'F' '58' '1' 'M' '7' '7']
 ['3' '33' '3' 'M' '34' '4' 'M' '2' '3']
 ['4' '43' '1' 'F' '64' '4' 'M' '7' '68']
 ['5' '1' '2' 'M' '87' '4' 'M' '7' '1']]

有什么方法可以做到吗? (我可以找到插入行但不是列的解决方案)

1 个答案:

答案 0 :(得分:5)

定义新列:

col = np.array(['1','2','3','4','5'])
col.shape = (5,1)

并在开头插入:

target = np.hstack((col, x))

要插入任何给定位置i,您可以这样做:

target = np.hstack((x[:,:i], col, x[:,i:]))

但在我看来,使用pandas数据框而不是numpy数组会是更好的选择......