Полезный альтернативный ответ на первый вопрос, использующий примеры из ответа tomeedee , заключается в использовании методов numpy vstack и column_stack :
Учитывая матрицу p,
>>> import numpy as np
>>> p = np.array([ [1,2] , [3,4] ])
расширенная матрица может быть сгенерирована:
>>> p = np.vstack( [ p , [5 , 6] ] )
>>> p = np.column_stack( [ p , [ 7 , 8 , 9 ] ] )
>>> p
array([[1, 2, 7],
[3, 4, 8],
[5, 6, 9]])
Эти методы могут быть удобны на практике, чем np.append (), поскольку они позволяют добавлять одномерные массивы в матрицу без каких-либо изменений, в отличие от следующего сценария:
>>> p = np.array([ [ 1 , 2 ] , [ 3 , 4 ] , [ 5 , 6 ] ] )
>>> p = np.append( p , [ 7 , 8 , 9 ] , 1 )
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.6/dist-packages/numpy/lib/function_base.py", line 3234, in append
return concatenate((arr, values), axis=axis)
ValueError: arrays must have same number of dimensions
В ответ на второй вопрос хорошим способом удаления строк и столбцов является использование индексации логических массивов следующим образом:
Учитывая матрицу p,
>>> p = np.arange( 20 ).reshape( ( 4 , 5 ) )
предположим, что мы хотим удалить строку 1 и столбец 2:
>>> r , c = 1 , 2
>>> p = p [ np.arange( p.shape[0] ) != r , : ]
>>> p = p [ : , np.arange( p.shape[1] ) != c ]
>>> p
array([[ 0, 1, 3, 4],
[10, 11, 13, 14],
[15, 16, 18, 19]])
Примечание - для реформированных пользователей Matlab - если вы хотите сделать это в одной строке, вам нужно дважды проиндексировать:
>>> p = np.arange( 20 ).reshape( ( 4 , 5 ) )
>>> p = p [ np.arange( p.shape[0] ) != r , : ] [ : , np.arange( p.shape[1] ) != c ]
Эта техника также может быть расширена для удаления наборов строк и столбцов, поэтому, если мы хотим удалить строки 0 & 2 и столбцы 1, 2 и 3, мы можем использовать numpy's setdiff1d функция для генерации желаемого логического индекса:
>>> p = np.arange( 20 ).reshape( ( 4 , 5 ) )
>>> r = [ 0 , 2 ]
>>> c = [ 1 , 2 , 3 ]
>>> p = p [ np.setdiff1d( np.arange( p.shape[0] ), r ) , : ]
>>> p = p [ : , np.setdiff1d( np.arange( p.shape[1] ) , c ) ]
>>> p
array([[ 5, 9],
[15, 19]])