Odpowiedzi:
>>> 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])
Zobacz także: „numpy.arange” i „reshape”, aby przydzielić pamięć
Przykład: (Przydział tablicy z kształtowaniem macierzy (3x4))
nrows = 3
ncols = 4
my_array = numpy.arange(nrows*ncols, dtype='double')
my_array = my_array.reshape(nrows, ncols)
[row, col]
. przecinek rozdziela się.
Czy to możliwe, że używasz tablicy NumPy ? Python ma moduł macierzy , ale nie obsługuje tablic wielowymiarowych. Normalne listy w języku Python są również jednowymiarowe.
Jeśli jednak masz prostą dwuwymiarową listę, taką jak ta:
A = [[1,2,3,4],
[5,6,7,8]]
następnie możesz wyodrębnić taką kolumnę:
def column(matrix, i):
return [row[i] for row in matrix]
Wyodrębnianie drugiej kolumny (indeks 1):
>>> column(A, 1)
[2, 6]
Lub alternatywnie po prostu:
>>> [row[1] for row in A]
[2, 6]
Jeśli masz tablicę podobną do
a = [[1, 2], [2, 3], [3, 4]]
Następnie wyodrębnij pierwszą kolumnę w ten sposób:
[row[0] for row in a]
Wynik wygląda następująco:
[1, 2, 3]
Sprawdź to!
a = [[1, 2], [2, 3], [3, 4]]
a2 = zip(*a)
a2[0]
jest to to samo, co powyżej, z wyjątkiem tego, że jest ładniejszy, zip działa, ale wymaga pojedynczych tablic jako argumentów, składnia * a rozpakowuje tablicę wielowymiarową na argumenty z jedną tablicą
a2 = zip(*a); a2 = list(a2); a2[0]
def get_col(arr, col):
return map(lambda x : x[col], arr)
a = [[1,2,3,4], [5,6,7,8], [9,10,11,12],[13,14,15,16]]
print get_col(a, 3)
funkcja map w Pythonie to kolejna droga.
>>> 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]])
jeśli chcesz drugą kolumnę możesz użyć
>>> x[:, 1]
array([ 1, 6, 11, 16])
arange()
Python3 poza Numpy. Ktoś?
Operator itemgetter również może pomóc, jeśli lubisz styl python w stylu zmniejszania mapy, a nie listy ze zrozumieniem, dla małej różnorodności!
# 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)
Myślę, że chcesz wyodrębnić kolumnę z tablicy, takiej jak tablica poniżej
import numpy as np
A = np.array([[1,2,3,4],[5,6,7,8],[9,10,11,12]])
Teraz, jeśli chcesz uzyskać trzecią kolumnę w formacie
D=array[[3],
[7],
[11]]
Następnie musisz najpierw uczynić tablicę macierzą
B=np.asmatrix(A)
C=B[:,2]
D=asarray(C)
A teraz możesz wykonywać mądre obliczenia, podobnie jak w Excelu.
powiedzmy, że mamy n X m
macierz ( n
wiersze i m
kolumny), powiedzmy 5 wierszy i 4 kolumny
matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16],[17,18,19,20]]
Aby wyodrębnić kolumny w pythonie, możemy użyć takiego rozumienia listy
[ [row[i] for row in matrix] for in range(4) ]
Możesz zastąpić 4 dowolną liczbą kolumn w macierzy. Wynik to
[ [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]
Jeśli masz w Pythonie dwuwymiarową tablicę (nie numpy), możesz wyodrębnić wszystkie kolumny w ten sposób,
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]))
Wykonanie tego kodu da,
>>> 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)
Oczywiście możesz wyodrębnić pojedynczą kolumnę według indeksu (np. columns[0]
)
Pomimo zip(*iterable)
transpozycji listy zagnieżdżonej możesz użyć następujących opcji, jeśli listy zagnieżdżone różnią się długością:
map(None, *[(1,2,3,), (4,5,), (6,)])
prowadzi do:
[(1, 4, 6), (2, 5, None), (3, None, None)]
Pierwsza kolumna to:
map(None, *[(1,2,3,), (4,5,), (6,)])[0]
#>(1, 4, 6)
„Trochę” późno…
W przypadku, gdy wydajność ma znaczenie, a dane mają kształt prostokąta, możesz również przechowywać je w jednym wymiarze i uzyskać dostęp do kolumn poprzez regularne krojenie, np.
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]
Fajne jest to, że jest naprawdę szybki. Jednak ujemne indeksy tutaj nie działają! Więc nie możesz uzyskać dostępu do ostatniej kolumny lub wiersza według indeksu -1.
Jeśli potrzebujesz indeksowania ujemnego, możesz nieco dostroić funkcje akcesora, np
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]
Wolę następną wskazówkę: nazwać macierz matrix_a
i użyć column_number
na przykład:
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]
Wystarczy użyć transpose (), aby uzyskać kolumny tak proste, jak wiersze
matrix=np.array(originalMatrix).transpose()
print matrix[NumberOfColum]
Wszystkie kolumny z macierzy na nową listę:
N = len(matrix)
column_list = [ [matrix[row][column] for row in range(N)] for column in range(N) ]