ChainedAssignmentError при добавлении условия в кадр данных pandasPython

Программы на Python
Ответить
Anonymous
 ChainedAssignmentError при добавлении условия в кадр данных pandas

Сообщение Anonymous »

Я продолжаю получать ошибку ChainedAssignmentError при добавлении условия в свой код. В этом базовом примере я проверяю, является ли столбец «один» буквой «e», и если да, то устанавливаю для столбца «Соответствие» значение 1.
Файл df обновляется правильно, я просто получаю предупреждение о будущем.
import pandas as pd

df = pd.DataFrame([list('ab0'),
list('ee0'),
list('ij0'),
list('ii0')],
columns=['one', 'two', 'Match'])
print(df)

df.loc[:,"Match"][df.loc[:,"one"] == "e"] = 1

print(df)

ВЫВОД
one two Match

0 a b 0

1 e e 0

2 i j 0

3 i i 0

FutureWarning: ChainedAssignmentError: behaviour will change in pandas 3.0!
You are setting values through chained assignment. Currently this works in certain cases, but when using Copy-on-Write (which will become the default behaviour in pandas 3.0) this will never work to update the original DataFrame or Series, because the intermediate object on which we are setting values will behave as a copy.
A typical example is when you are setting values in a column of a DataFrame, like:

df["col"][row_indexer] = value

Use `df.loc[row_indexer, "col"] = values` instead, to perform the assignment in a single step and ensure this keeps updating the original `df`.

See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/s ... sus-a-copy

one two Match

0 a b 0

1 e e 1

2 i j 0

3 i i 0


Подробнее здесь: https://stackoverflow.com/questions/798 ... -dataframe
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»