teratail header banner
teratail header banner
質問するログイン新規登録

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

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

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

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

2回答

1875閲覧

python DataFrameに拡張for文

jotaku

総合スコア40

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/06/05 01:35

0

0

pythonで拡張for文を使用する際に

DataFrame型の変数から1つずつ取り出す際に先頭のcloumの文字列を取り出してしまって困っております

columやindexを無視して中の数字データだけを拡張for文で取得する方法はございますか?

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

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

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

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

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

quickquip

2019/06/05 02:42

「拡張for文」とはなんでしょうか。「先頭のcloumの」とはなんでしょうか。「columやindexを無視して」とはなんでしょうか。現在のコードをここに書いてないのはなぜでしょうか。意味を解釈するのに回答者に負担を強いるだけです。
guest

回答2

0

おそらく↓のページの中のいずれかが使いたい処理に該当するのでしょう。

pandas.DataFrameのforループ処理(イテレーション) | note.nkmk.me

投稿2019/06/05 04:29

hayataka2049

総合スコア30939

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

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

0

Pandasは、データ分析用のライブラリーです。そのため、DataFrameは、データをcolumn単位で一次元行列で持っています。以下のように、DataFrameからforで 1 つずつ取り出すとcloumn名が取り出されます。

python

1for d in df: 2 print(d)

Pandasでは、for文を使うと処理速度が遅いので、通常ベクトル演算使います。もちろん、pandasでも以下のようにiterrows()メソッドを使うと、1行ずつデータを取得することができますが、処理が非常に遅いので普通に使うものではありません。

python

1for d in df.iteritems(): 2 print(d)

もし、Pandas でfor文をどうしても使う必要がある場合は、速度を要求される場合は CythonやNumba等を使って処理をするようになります。処理速度である程度妥協できるのであれば、df.apply()を使うか、又は、column単位で取り出すことが容易なので、下のように必要なcolumnだけをzip関数でまとめてforでループにします。iterrows()を使うよりもかなり速いです。PandasでもSeriesの場合は、for文で各要素を取り出すことができます。

for a, b in zip(df['a'], df['b']): print(a, b)

拡張for文と言っているのでJavaかC++の世界を知っていると思われますが、本当にfor文が必要な処理であれば、Pandasを使うよりもJavaやC++の方が処理に遥かに向いています。

投稿2019/06/05 04:21

編集2019/06/05 06:46
YasuhiroNiji

総合スコア584

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

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

hayataka2049

2019/06/05 04:35

>もし、Pandas でfor文をどうしても使う必要がある場合は、CythonやNumba等を使ってC/C++で処理をするようになります。 NumbaはJITコンパイラなのでC/C++には直接関係はありません。また、データがそれほど大きくなくて、許容できる速度で実行できるとき「妥協してループする(か、applyなどで処理する)」のはさほど珍しいことではないはずです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問