質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

2回答

6642閲覧

PythonでSettingWithCopyWarningがでる

i113

総合スコア74

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

1クリップ

投稿2021/05/12 04:40

pythonで以下のようにしたところSettingWithCopyWarningという警告が出ました。
プログラムはそのまま進行しましたが気持ちが悪いので解決したいです。

python

1print(df) 2df['C'] = df['A']/df['B'] 3print(df)

output

1 A B 25 3 2 36 11 5 414 2 1 515 9 3 618 5 4 7... ... ... 841 25 10 944 8 2 1047 8 8 1148 17 4 1251 6 3 13 14[20 rows x 2 columns] 15hogehoge.py:84: SettingWithCopyWarning: 16A value is trying to be set on a copy of a slice from a DataFrame. 17Try using .loc[row_indexer,col_indexer] = value instead 18 19See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy 20 df['C'] = df['A']/df['B'] 21 A B C 225 3 2 1.5 236 11 5 2.2 2414 2 1 2.0 2515 9 3 3.0 2618 5 4 1.25 27... ... ... ... 2841 25 10 2.5 2944 8 2 4.0 3047 8 8 1.0 3148 17 4 4.25 3251 6 3 2.0 33 34[20 rows x 3 columns]

.locを使えと書かれているので試みましたが駄目でした。

python

1print(df) 2df.loc[:,'C'] = df.loc[:,'A']/df.loc[:,'B'] 3print(df)

output

1 A B 25 3 2 36 11 5 414 2 1 515 9 3 618 5 4 7... ... ... 841 25 10 944 8 2 1047 8 8 1148 17 4 1251 6 3 13 14[20 rows x 2 columns] 15/home/hoge/anaconda3/lib/python3.7/site-packages/pandas/core/indexing.py:1596: SettingWithCopyWarning: 16A value is trying to be set on a copy of a slice from a DataFrame. 17Try using .loc[row_indexer,col_indexer] = value instead 18 19See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy 20 self.obj[key] = _infer_fill_value(value) 21/home/hoge/anaconda3/lib/python3.7/site-packages/pandas/core/indexing.py:1743: SettingWithCopyWarning: 22A value is trying to be set on a copy of a slice from a DataFrame. 23Try using .loc[row_indexer,col_indexer] = value instead 24 25See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy 26 isetter(ilocs[0], value) 27 A B C 285 3 2 1.5 296 11 5 2.2 3014 2 1 2.0 3115 9 3 3.0 3218 5 4 1.25 33... ... ... ... 3441 25 10 2.5 3544 8 2 4.0 3647 8 8 1.0 3748 17 4 4.25 3851 6 3 2.0 39 40[20 rows x 3 columns]

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

こちらに書かれている部分の問題ではなく、この前に書かれているコードに原因があります。
dfのインデックスが飛び飛びになっていることから、dfは別のデータフレームから抜き出して作成したものなのではないですか?
df = df_orig[df_orig['B'] != 0] みたいな。

このとき、dfを変更すると、
・dfだけを変更しようとしているのか
・df_origも変更したいのか
がわからないため、warningが出ます。

前者の場合、

python

1df = df.copy() 2df['C'] = df['A'] / df['B']

のように、df.copy()でコピーであることを明示してやればよいです。

後者の場合は、

python

1df_orig.loc[df_orig['B'] != 0, 'C'] = df['A'] / df['B']

のように、元のデータフレームで.locを使って代入してやる必要があります。

投稿2021/05/12 07:16

bsdfan

総合スコア4794

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

i113

2021/05/13 02:28

どうも有り難うございます。 上手くいきました。
guest

0

こんにちは。

問題文読ませていただきました。

SettingWithCopyWarningに関してこちらの記事がわかりやすくまとまっていますので、ご確認&対応いただけますでしょうか?
pandasのSettingWithCopyWarningの対処法

投稿2021/05/12 07:16

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問