Попытка замаскировать видео в форму SVG

Как вы можете видеть, оператор AND оставляет каждую строку, в которой по крайней мере одно значение равно -1. С другой стороны, оператор OR требует, чтобы оба значения были равны -1, чтобы отбросить их.

Правильно. Помните, что вы пишете условие с точки зрения того, что вы хотите сохранить , а не с точки зрения того, что вы хотите сбросить. Для df1:

df1 = df[(df.a != -1) & (df.b != -1)]

Вы говорите: «Сохраните строки, в которых df.a не является -1, а df.b не равно -1», что равнозначно удалению каждая строка, в которой хотя бы одно значение равно -1.

Для df2:

df2 = df[(df.a != -1) | (df.b != -1)]

Вы говорите: «Сохраните строки, в которых либо df.a, либо df.b не равно -1 ", что совпадает с удалением строк, где оба значения равны -1.

PS: скованный доступ, такой как df['a'][1] = -1, может вызвать у вас проблемы. Лучше привыкнуть к использованию .loc и .iloc.

0
задан WillingLearner 16 January 2019 в 18:18
поделиться