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

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

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

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

2回答

681閲覧

PythonのDataFrameのilocの列指定の仕方が分からない

1mzmk

総合スコア42

Python 3.x

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2020/04/05 17:55

編集2020/04/05 17:58

PythonのDataFrameのilocの使用について質問があります。

ilocは行と列の番号を指定してデータを抽出するために使用すると認識しています。
しかし、なぜ下のようなコードでAgeの要素以外のデータを抽出することができるのでしょうか。

Python

1csv_titanic.iloc[:,csv_titanic.columns!="Age"]

また下のように"Age"の要素を抽出するコードだとエラーを吐くのでしょうか。

Python

1csv_titanic.iloc[:,csv_titanic.columns ="Age"]

ご回答よろしくお願いします。

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

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

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

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

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

guest

回答2

0

質問のコードにて何故データを抽出できるのか、出来ないのかの説明は hayataka2049 さんが回答されている通りとなります。
ですので、私の回答は補足となります。

pandas.Index クラスには get_loc() という Index名(Column名)から対応するIndex値を取得するmethodがありますので、以下のように ilocで列指定する際にこれを使用する方法もあります。

Python

1csv_titanic.iloc[:, csv_titanic.columns.get_loc("Age")]

https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.Index.get_loc.html

データをフィルタリングする際に、列の指定をBoolean配列で行った場合の結果は DataFrame型で得られますが、この方法の場合は数値('Index値')で指定することになるので、結果は Series型となります。

Python

1import pandas as pd 2import numpy as np 3 4# ダミーデータ生成 5df =pd.DataFrame(np.arange(9).reshape((3,3)), columns=['A','B','C']) 6# A B C 7#0 0 1 2 8#1 3 4 5 9#2 6 7 8 10 11# 以下のように比較演算によってBoolean配列が得られる 12print(df.columns == 'B') 13# [False True False] 14 15# 列の指定値としてBoolean値の配列を渡す場合 16#( 結果はDataFrameで得られる ) 17print(df.iloc[:, df.columns == 'B']) 18# B 19# 0 1 20# 1 4 21# 2 7 22 23# カラム名に対応したIndex値を得る方法 24print(df.columns.get_loc('B')) 25# 1 26 27# Index値を渡すことでもフィルタリングする 28#( 結果はSeriesで得られる ) 29print(df.iloc[:, df.columns.get_loc('B')]) 30# 0 1 31# 1 4 32# 2 7 33# Name: B, dtype: int64

投稿2020/04/05 23:49

magichan

総合スコア15898

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

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

1mzmk

2020/04/06 14:44

ご丁寧に解説していただきありがとうございました。
guest

0

ベストアンサー

ブール値の配列によるマスクを使って行・列の選択を行うことができます。numpyにもある機能ですね(あちらが元祖と言うべきか)。

細かい説明等は下のリンクのドキュメントを参照してください。それか「pandas boolean 選択」とかで検索すれば解説記事が出るでしょう。

Another common operation is the use of boolean vectors to filter the data.

Indexing and selecting data — pandas 1.0.3 documentation

 

csv_titanic.columns ="Age"

Pythonの等値比較演算子は==です。=は比較で使うことはできません。

投稿2020/04/05 21:14

hayataka2049

総合スコア30933

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問