Панды: несколько условий при индексации фрейма данных - неожиданное поведение

Я фильтрую строки в кадре данных по значениям в двух столбцах.

По какой-то причине оператор OR ведет себя так, как я ожидал, и оператор AND будет вести себя, и наоборот.

Мой тестовый код:

import pandas as pd

df = pd.DataFrame({'a': range(5), 'b': range(5) })

# let's insert some -1 values
df['a'][1] = -1
df['b'][1] = -1
df['a'][3] = -1
df['b'][4] = -1

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

print pd.concat([df, df1, df2], axis=1,
                keys = [ 'original df', 'using AND (&)', 'using OR (|)',])

И результат:

      original df      using AND (&)      using OR (|)    
             a  b              a   b             a   b
0            0  0              0   0             0   0
1           -1 -1            NaN NaN           NaN NaN
2            2  2              2   2             2   2
3           -1  3            NaN NaN            -1   3
4            4 -1            NaN NaN             4  -1

[5 rows x 6 columns]

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

Я использую панды 0.13.1.

Ответы на вопрос(3)

Ваш ответ на вопрос