Предположим, у вас есть структурированный массив a
:
import numpy as np
a = np.array([1, 2, 3, 4, 5, 6], dtype=[('val', 'i4')])
print(a)
[(1,) (2,) (3,) (4,) (5,) (6,)]
Теперь, если я хочу изменить одну из записей на другое значение, следующие два способа кажутся эквивалентными ( Случай I ):
# both of these work
"""version a)"""
a['val'][1] = 10
print(a)
[( 1,) (10,) ( 3,) ( 4,) ( 5,) ( 6,)]
"""version b)"""
a[1]['val'] = 2
print(a)
[(1,) (2,) (3,) (4,) (5,) (6,)]
Но эта двусмысленность (не уверен, что это правильный термин) сломается, если мы попытаемся изменить более одной записи ( Случай II ):
"""version a)"""
a['val'][[0, 1]] = 15
print(a)
[(15,) (15,) ( 3,) ( 4,) ( 5,) ( 6,)]
# this works
"""version b)"""
a[[0, 1]]['val'] = 5
print(a)
[(15,) (15,) ( 3,) ( 4,) ( 5,) ( 6,)]
# this has no effect
Я подумал, что, возможно, во втором случае, версия b), создается новый объект, поэтому назначение нового значения этим записям влияет только на новый объект, но не на исходный. Но и в первом случае, версия b), создается новый объект, так как оба следующих оператора возвращают False
:
print(a[1]['val'] is a['val'][1])
print(a['val'][[0, 1]] is a[[0, 1]]['val'])
Тот факт, что эта неопределенность дается только в первом Случай, но не второй, кажется мне противоречивым, хотя бы сбивающим с толку. Чего мне не хватает?