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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Python 3.x

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

Q&A

解決済

4回答

5754閲覧

python pandas DataFrameで特定の行・列に値を代入

valuetheater

総合スコア18

Python 3.x

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

0グッド

0クリップ

投稿2019/04/14 04:41

前提・実現したいこと

csvファイルから読み込んでいますのでデータフレームには行・列・値は入っています。
それを再編集する形になります。
現在はdf.loc, dfilocを使用せずに代入を行っていますが推奨されない文法の為、warningが出ます
最適な方法をご教授お願いします。

発生している問題・エラーメッセージ

SettingWithCopyWarning:
A value is trying to be set on a copy of a slice from a DataFrame

See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy

該当のソースコード

pyton

1 for i, flag in enumerate(df['category']): 2 if not flag: 3 if (num_list[i][2] == 14) & (num_list[i][0] == 2) & (num_list[i][1] != 13): 4 df['category'][i] = True

試したこと

補足情報(FW/ツールのバージョンなど)

df row=1000行, column=10列
value = True or False

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

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

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

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

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

guest

回答4

0

Python

1df.iat[i, df.columns.get_loc('category')] = True

でどうでしょうか

df.columns.get_loc('category')はループ外で変数に入れておいても良いかと思います。

投稿2019/04/14 07:40

magichan

総合スコア15898

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

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

magichan

2019/04/14 07:41

すでに解決されておりましたね。失礼しました。
guest

0

自己解決

回答してくださりありがとうございました。
おかげでヒントになり解決できました。

df.columns.get_loc('a')でカラムを指定できる

df.iloc[2, df.columns.get_loc('a')]

投稿2019/04/14 07:31

valuetheater

総合スコア18

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

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

0

python

1df.ix[i, 'category'] = True

あたりでしょうか。

投稿2019/04/14 05:33

hayataka2049

総合スコア30933

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

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

valuetheater

2019/04/14 07:19

回答ありがとうございます。 ixは非推奨と思われますがいかがでしょうか? 出来れば別の方法を提案されると嬉しいです。
hayataka2049

2019/04/14 13:16

magichanさんの方法でいいと思います。ただし、パフォーマンスが問題になるなら行インデックスの取得はループ外に追い出してください。
hayataka2049

2019/04/14 13:17

また、ループをやめてmap等で処理するのが一番スマートです。
guest

0

訂正

この回答に掲載したコードは、行、列共にインデックス指定でないとできませんでした。
よくコードを読んでおらず申し訳ないです。
恐らく正解はhayataka2049様、掲載のコードになりますので、そちらを参考になさった方が良いと思われます。


尚、行番号と列番号は質問者様掲載コードと同様、0始まり

以下コード

python

1df.iat[行番号,列番号] = 代入したい値

投稿2019/04/14 05:12

編集2019/04/14 05:37
kou0179

総合スコア304

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問