Я бы использовал |оператор в этом примере, потому что значение не может быть равно указанному значению И равно другому.В моем примере я не использовал функцию .loc для поиска результатов, а просто использовал функцию print для иллюстрации точки:
import datetime
import pandas as pd
dates = [datetime.datetime(2001, 1, 1), datetime.datetime(2001, 2, 1), datetime.datetime(2001, 3, 1), datetime.datetime(2001, 4, 1)]
dates_2 = []
for date in dates:
date = date.strftime('%y-%m-%d')
dates_2.append(date)
df = pd.DataFrame({'Value1':[01, 02, 03, 04], 'Value2':[01, 00, 01, 101]}, index=dates)
print(df[(df['Value2'] == 0) | (df['Value2'] >= 100)])
Как вы можете видеть выше, мы используем скобки для оценки двух условий какВы сделали, но разница в том, что мы использовали |оператор в этом примере.Возможно, у вас просто была логическая ошибка.Вывод:
Value1 Value2
2001-02-01 2 0
2001-04-01 4 101
Очевидно, что использование .loc должно просто вернуть значения для столбца Value2.Я только сделал оператор печати в этом примере, чтобы проиллюстрировать более широкий вопрос.