numpy.where()関数の詳細
21606 ワード
pythonのnumpy.where()関数はやはり奇抜です.公式文書の例を見ると、使い方が説明されていないような気がします.後で主にこれを言います.
まず公式文書の中の例を貼って、文字の説明は貼らないで、直接例を見てもっと分かりやすいと信じています.
以上が公式文書の例です
次に、別の特殊な例を説明します.
一見、この出力が何を説明しているのか分からないので、np.whereの場合はよくこの問題に遭遇します.実はこの出力表現は、第1列0,2,0が5より大きい(whereの条件)、第2列0,2,1が5より大きい....カラムのこのデータはvalueに対するインデックス(index)と見なすことができます.
まず公式文書の中の例を貼って、文字の説明は貼らないで、直接例を見てもっと分かりやすいと信じています.
Examples
--------
>>> a = np.arange(10)
>>> a
array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
>>> np.where(a < 5, a, 10*a)
array([ 0, 1, 2, 3, 4, 50, 60, 70, 80, 90])
This can be used on multidimensional arrays too:
>>> np.where([[True, False], [True, True]],
... [[1, 2], [3, 4]],
... [[9, 8], [7, 6]])
array([[1, 8],
[3, 4]])
The shapes of x, y, and the condition are broadcast together:
>>> x, y = np.ogrid[:3, :4]
>>> np.where(x < y, x, 10 + y) # both x and 10+y are broadcast
array([[10, 0, 0, 0],
[10, 11, 1, 1],
[10, 11, 12, 2]])
>>> a = np.array([[0, 1, 2],
... [0, 2, 4],
... [0, 3, 6]])
>>> np.where(a < 4, a, -1) # -1 is broadcast
array([[ 0, 1, 2],
[ 0, 2, -1],
[ 0, 3, -1]])
以上が公式文書の例です
次に、別の特殊な例を説明します.
import numpy as np
>>> a = np.arange(27).reshape(3,3,3)
>>> a
array([[[ 0, 1, 2],
[ 3, 4, 5],
[ 6, 7, 8]],
[[ 9, 10, 11],
[12, 13, 14],
[15, 16, 17]],
[[18, 19, 20],
[21, 22, 23],
[24, 25, 26]]])
>>> np.where(a > 5)
(array([0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2],
dtype=int64),
array([2, 2, 2, 0, 0, 0, 1, 1, 1, 2, 2, 2, 0, 0, 0, 1, 1, 1, 2, 2, 2],
dtype=int64),
array([0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2, 0, 1, 2],
dtype=int64))
一見、この出力が何を説明しているのか分からないので、np.whereの場合はよくこの問題に遭遇します.実はこの出力表現は、第1列0,2,0が5より大きい(whereの条件)、第2列0,2,1が5より大きい....カラムのこのデータはvalueに対するインデックス(index)と見なすことができます.