NumPy - zaawansowane indeksowanie
Możliwe jest dokonanie wyboru z ndarray, który jest sekwencją inną niż krotka, obiekt ndarray o typie danych typu integer lub Boolean lub krotka z co najmniej jednym elementem będącym obiektem sekwencji. Zaawansowane indeksowanie zawsze zwraca kopię danych. W związku z tym cięcie przedstawia tylko widok.
Istnieją dwa rodzaje zaawansowanego indeksowania - Integer i Boolean.
Indeksowanie liczb całkowitych
Mechanizm ten pomaga w wyborze dowolnego elementu w tablicy na podstawie jego indeksu N-wymiarowego. Każda tablica liczb całkowitych reprezentuje liczbę indeksów w tym wymiarze. Gdy indeks składa się z tylu tablic całkowitych, ile wynosi wymiary docelowej tablicy ndarray, staje się to proste.
W poniższym przykładzie wybrano jeden element określonej kolumny z każdego wiersza obiektu ndarray. W związku z tym indeks wierszy zawiera wszystkie numery wierszy, a indeks kolumny określa element, który ma zostać wybrany.
Przykład 1
import numpy as np
x = np.array([[1, 2], [3, 4], [5, 6]])
y = x[[0,1,2], [0,1,0]]
print y
Jego wynik byłby następujący -
[1 4 5]
Wybór obejmuje elementy w (0,0), (1,1) i (2,0) z pierwszej tablicy.
W poniższym przykładzie zaznaczono elementy umieszczone w rogach tablicy 4X3. Wskaźniki wierszy to [0, 0] i [3,3], podczas gdy indeksy kolumn to [0,2] i [0,2].
Przykład 2
import numpy as np
x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]])
print 'Our array is:'
print x
print '\n'
rows = np.array([[0,0],[3,3]])
cols = np.array([[0,2],[0,2]])
y = x[rows,cols]
print 'The corner elements of this array are:'
print y
Wynik tego programu jest następujący -
Our array is:
[[ 0 1 2]
[ 3 4 5]
[ 6 7 8]
[ 9 10 11]]
The corner elements of this array are:
[[ 0 2]
[ 9 11]]
Wynikowe zaznaczenie to obiekt ndarray zawierający elementy narożne.
Indeksowanie zaawansowane i podstawowe można łączyć za pomocą jednego wycinka (:) lub wielokropka (…) z tablicą indeksów. W poniższym przykładzie zastosowano wycinek dla wiersza i zaawansowany indeks dla kolumny. Rezultat jest taki sam, gdy plasterek jest używany do obu. Ale zaawansowany indeks powoduje kopiowanie i może mieć inny układ pamięci.
Przykład 3
import numpy as np
x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]])
print 'Our array is:'
print x
print '\n'
# slicing
z = x[1:4,1:3]
print 'After slicing, our array becomes:'
print z
print '\n'
# using advanced index for column
y = x[1:4,[1,2]]
print 'Slicing using advanced index for column:'
print y
Wynik tego programu byłby następujący -
Our array is:
[[ 0 1 2]
[ 3 4 5]
[ 6 7 8]
[ 9 10 11]]
After slicing, our array becomes:
[[ 4 5]
[ 7 8]
[10 11]]
Slicing using advanced index for column:
[[ 4 5]
[ 7 8]
[10 11]]
Indeksowanie tablic logicznych
Ten typ zaawansowanego indeksowania jest używany, gdy wynikowy obiekt ma być wynikiem operacji logicznych, takich jak operatory porównania.
Przykład 1
W tym przykładzie elementy większe niż 5 są zwracane w wyniku indeksowania logicznego.
import numpy as np
x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]])
print 'Our array is:'
print x
print '\n'
# Now we will print the items greater than 5
print 'The items greater than 5 are:'
print x[x > 5]
Wynik tego programu byłby:
Our array is:
[[ 0 1 2]
[ 3 4 5]
[ 6 7 8]
[ 9 10 11]]
The items greater than 5 are:
[ 6 7 8 9 10 11]
Przykład 2
W tym przykładzie elementy NaN (Not a Number) są pomijane przy użyciu ~ (operator dopełniacza).
import numpy as np
a = np.array([np.nan, 1,2,np.nan,3,4,5])
print a[~np.isnan(a)]
Jego wyjście byłoby -
[ 1. 2. 3. 4. 5.]
Przykład 3
Poniższy przykład pokazuje, jak odfiltrować niezłożone elementy z tablicy.
import numpy as np
a = np.array([1, 2+6j, 5, 3.5+5j])
print a[np.iscomplex(a)]
Tutaj wynik jest następujący -
[2.0+6.j 3.5+5.j]