>  기사  >  백엔드 개발  >  .loc 인덱싱과 함께 설정WithCopyWarning이 지속되는 이유는 무엇입니까?

.loc 인덱싱과 함께 설정WithCopyWarning이 지속되는 이유는 무엇입니까?

DDD
DDD원래의
2024-10-28 08:03:02784검색

Why Does the SettingWithCopyWarning Persist with .loc Indexing?

SettingWithCopyWarning이 .loc 인덱싱과 함께 지속됨

데이터 조작을 위해 .loc[row_indexer,col_indexer] = 값을 사용할 때 다음과 같은 문제가 계속 발생할 수 있습니다. CopyWarning으로 설정. 이는 일반적으로 변경 사항을 적용하기 전에 기본 데이터 프레임을 복사할 때 발생합니다.

단계별 오류 재현

다음 데이터 프레임 df를 고려하세요.

<code class="python">import pandas as pd

d = {'col1': [1, 2, 3, 4], 'col2': [3, 4, 5, 6]}
df = pd.DataFrame(data=d)</code>

처음에 .loc를 사용하여 열을 수정하면 경고가 발생하지 않습니다.

<code class="python">df['new_column'] = None
df.loc[0, 'new_column'] = 100</code>

그러나 df가 새 데이터 프레임 new_df를 생성하도록 필터링된 경우 이후에 .loc를 사용하여 수정하면 경고가 발생할 수 있습니다.

<code class="python">new_df = df.loc[df.col1 > 2]
new_df.loc[2, 'new_column'] = 100</code>

이는 new_df가 df의 뷰 또는 슬라이스이고 new_df에 적용된 변경 사항이 df로 다시 전파되지 않기 때문에 발생합니다.

해결책

경고를 제거하려면 필터를 적용하기 전에 df의 복사본을 만들어야 합니다.

<code class="python">new_df_copy = df.loc[df.col1 > 2].copy()
new_df_copy.loc[2, 'new_column'] = 100</code>

.copy()를 사용하면 df와 독립적인 새 데이터 프레임이 생성되어 변경이 허용됩니다. df를 수정하지 않고 new_df_copy에 추가합니다.

convert_objects에 대한 방지

SettingWithCopyWarning은 Convert_objects 함수에 의해 트리거될 수도 있습니다. 이를 방지하려면 Convert_objects:

<code class="python">value1['Total Population'] = value1['Total Population'].astype(str).convert_objects(convert_numeric=True)</code>
를 호출하기 전에 .astype(str)을 사용하세요.

위 내용은 .loc 인덱싱과 함께 설정WithCopyWarning이 지속되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.