답변:
>>> import numpy as np
>>> A = np.array([[1,2,3,4],[5,6,7,8]])
>>> A
array([[1, 2, 3, 4],
[5, 6, 7, 8]])
>>> A[:,2] # returns the third columm
array([3, 7])
"numpy.arange"및 "reshape"도 참조하여 메모리를 할당하십시오
예 : (매트릭스 (3x4)의 형태로 배열 할당)
nrows = 3
ncols = 4
my_array = numpy.arange(nrows*ncols, dtype='double')
my_array = my_array.reshape(nrows, ncols)
[row, col]
. 쉼표가 구분됩니다.
NumPy 배열을 사용하고 있습니까? 파이썬에는 배열 모듈이 있지만 다차원 배열을 지원하지 않습니다. 일반적인 파이썬리스트도 1 차원입니다.
그러나 다음과 같은 간단한 2 차원 목록이있는 경우 :
A = [[1,2,3,4],
[5,6,7,8]]
다음과 같이 열을 추출 할 수 있습니다.
def column(matrix, i):
return [row[i] for row in matrix]
두 번째 열 추출 (인덱스 1) :
>>> column(A, 1)
[2, 6]
또는 간단하게 :
>>> [row[1] for row in A]
[2, 6]
당신이 같은 배열을 가지고 있다면
a = [[1, 2], [2, 3], [3, 4]]
그런 다음 첫 번째 열을 다음과 같이 추출하십시오.
[row[0] for row in a]
결과는 다음과 같습니다.
[1, 2, 3]
확인 해봐!
a = [[1, 2], [2, 3], [3, 4]]
a2 = zip(*a)
a2[0]
그것은 zip이 작업을 수행하는 것이 더 깔끔하지만 인수로 단일 배열을 필요로한다는 것을 제외하고는 위와 동일합니다. * a 구문은 다차원 배열을 단일 배열 인수로 압축 해제합니다
a2 = zip(*a); a2 = list(a2); a2[0]
>>> x = arange(20).reshape(4,5)
>>> x array([[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14],
[15, 16, 17, 18, 19]])
두 번째 열을 원한다면 사용할 수 있습니다
>>> x[:, 1]
array([ 1, 6, 11, 16])
arange()
numpy 외부의 Python3에서 문서를 찾을 수 없습니다 . 누군가?
약간의 다양성을 위해 목록 이해보다는 맵 축소 스타일 파이썬을 좋아한다면 itemgetter 연산자도 도움이 될 수 있습니다!
# tested in 2.4
from operator import itemgetter
def column(matrix,i):
f = itemgetter(i)
return map(f,matrix)
M = [range(x,x+5) for x in range(10)]
assert column(M,1) == range(1,11)
아래 배열과 같은 배열에서 열을 추출하고 싶다고 생각합니다.
import numpy as np
A = np.array([[1,2,3,4],[5,6,7,8],[9,10,11,12]])
이제 세 번째 열을 형식으로 얻으려면
D=array[[3],
[7],
[11]]
그런 다음 먼저 배열을 행렬로 만들어야합니다
B=np.asmatrix(A)
C=B[:,2]
D=asarray(C)
이제 Excel에서와 마찬가지로 요소 별 계산을 수행 할 수 있습니다.
n X m
행렬 ( n
행과 m
열)이 5 행과 4 열 이라고 가정 해 봅시다.
matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16],[17,18,19,20]]
파이썬에서 열을 추출하려면 다음과 같이 목록 이해를 사용할 수 있습니다
[ [row[i] for row in matrix] for in range(4) ]
행렬의 열 수에 따라 4를 바꿀 수 있습니다. 결과는
[ [1,5,9,13,17],[2,10,14,18],[3,7,11,15,19],[4,8,12,16,20] ]
array = [[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16]]
col1 = [val[1] for val in array]
col2 = [val[2] for val in array]
col3 = [val[3] for val in array]
col4 = [val[4] for val in array]
print(col1)
print(col2)
print(col3)
print(col4)
Output:
[1, 5, 9, 13]
[2, 6, 10, 14]
[3, 7, 11, 15]
[4, 8, 12, 16]
파이썬 (numpy 아님)에 2 차원 배열이있는 경우 모든 열을 추출 할 수 있습니다.
data = [
['a', 1, 2],
['b', 3, 4],
['c', 5, 6]
]
columns = list(zip(*data))
print("column[0] = {}".format(columns[0]))
print("column[1] = {}".format(columns[1]))
print("column[2] = {}".format(columns[2]))
이 코드를 실행하면
>>> print("column[0] = {}".format(columns[0]))
column[0] = ('a', 'b', 'c')
>>> print("column[1] = {}".format(columns[1]))
column[1] = (1, 3, 5)
>>> print("column[2] = {}".format(columns[2]))
column[2] = (2, 4, 6)
물론, 당신은 인덱스에 의해 하나의 열을 추출 할 수 있습니다 (예를 들어 columns[0]
)
늦게 '비트'...
성능 문제와 데이터가 직사각형 모양 인 경우 한 차원으로 저장하고 정기적 인 슬라이싱을 통해 열에 액세스 할 수도 있습니다.
A = [[1,2,3,4],[5,6,7,8]] #< assume this 4x2-matrix
B = reduce( operator.add, A ) #< get it one-dimensional
def column1d( matrix, dimX, colIdx ):
return matrix[colIdx::dimX]
def row1d( matrix, dimX, rowIdx ):
return matrix[rowIdx:rowIdx+dimX]
>>> column1d( B, 4, 1 )
[2, 6]
>>> row1d( B, 4, 1 )
[2, 3, 4, 5]
깔끔한 것은 이것이 정말 빠르다는 것입니다. 그러나 음수 색인은 여기에서 작동하지 않습니다! 따라서 인덱스 -1로 마지막 열 또는 행에 액세스 할 수 없습니다.
네거티브 인덱싱이 필요한 경우 액세서 기능을 약간 조정할 수 있습니다.
def column1d( matrix, dimX, colIdx ):
return matrix[colIdx % dimX::dimX]
def row1d( matrix, dimX, dimY, rowIdx ):
rowIdx = (rowIdx % dimY) * dimX
return matrix[rowIdx:rowIdx+dimX]
다음 힌트를 선호합니다. matrix_a
column_number
예를 들어 하고 사용합니다 .
import numpy as np
matrix_a = np.array([[1,2,3,4],[5,6,7,8],[9,10,11,12]])
column_number=2
# you can get the row from transposed matrix - it will be a column:
col=matrix_a.transpose()[column_number]
행렬에서 새 목록으로의 모든 열 :
N = len(matrix)
column_list = [ [matrix[row][column] for row in range(N)] for column in range(N) ]