Kaggleなどでデータ分析を行う際の探索的データ解析(EDA)の段階で、
データの構造を把握する目的で自分自身がよく使う便利な関数やライブラリをまとめました。
データはKaggleのTitanicのTrainデータを使用します
https://www.kaggle.com/c/titanic/data
###■ライブラリの読み込み
import numpy as np
import pandas as pd
###■データの読み込み
df = pd.read_csv('titanic/train.csv')
###■データの基本情報、基本統計量の出力
- まずは最初の5行までを出力し、データを実際に見てみる
df.head()
#()に行数を入力し出力行数を変更可能
data:image/s3,"s3://crabby-images/7798d/7798df6cb5b0ad398e95e29b506aaab8aee3e7cb" alt="Screen Shot 2019-02-09 at 19.37.02.png"
- 要約統計量を出力
df.describe()
data:image/s3,"s3://crabby-images/c3938/c39387f33a1e2cbfb0ded0bc6fa95da03b1c84be" alt="Screen Shot 2019-02-09 at 19.39.23.png"
- オブジェクト型の要素数、ユニーク数、最頻値、最頻 値の出現回数を表示
df.describe(include = 'O')
data:image/s3,"s3://crabby-images/d5b2b/d5b2b0d73fa92dc43f984dfed3358b9bdf4f2bdb" alt="Screen Shot 2019-02-09 at 19.54.00.png"
- 全列の(データ数、nullの有無、データ型)を表示
df.info()
data:image/s3,"s3://crabby-images/6f512/6f5124f1bf7eb15fc6dd90c28b15bd52129e678f" alt="Screen Shot 2019-02-09 at 19.43.33.png"
- その他便利なコマンド
df.tail() #最後から5行表示
df.shape #(行数, 列数)を表示
df.size #データ数を表示
df.dtypes #データ型を表示
df.columns #列一覧を表示
df.corr() #全列の相関係数表示
###■pandas-profilingでプロファイリング
2行のコードで、読み込むデータの様々な情報をグラフを含めて出力できます
import pandas_profiling #インポート
pandas_profiling.ProfileReport(df) #実行
別記事で詳しく解説しています
https://qiita.com/ryo111/items/705347799a984acd5d08
###■各列のユニーク値の種類数を表示
df.apply(lambda x: x.nunique())
data:image/s3,"s3://crabby-images/d712d/d712d72376af30bb9fe6774c7c9f784a58ab1418" alt="Screen Shot 2019-02-09 at 22.19.40.png"
###■各列の欠損値の確認
df.isnull().sum()
data:image/s3,"s3://crabby-images/fca02/fca02b79437c616b32900fdf7ea77ea1245ccd57" alt="Screen Shot 2019-02-09 at 22.24.52.png"
###■指定の列の他の列との相関係数を表示
目的変数を入力すれば、他の変数との相関関係をシンプルに出力できるので便利
df.corr()["Survived"].sort_values()
data:image/s3,"s3://crabby-images/40383/403831e7eeee4bc111e0a7bd0bcbe96b2ab9f793" alt="Screen Shot 2019-02-10 at 18.33.09.png"
###■数値データ(もしくはオブジェクトデータ)の列のみのインデックスを出力
#数値データのみ
df.select_dtypes(include=[np.number]).columns
data:image/s3,"s3://crabby-images/52c58/52c58e8d7d15866e587c4b6966f42cfa739aad60" alt="Screen Shot 2019-02-09 at 21.08.30.png"
#オブジェクトデータのみ
df.select_dtypes(include=[np.object]).columns
data:image/s3,"s3://crabby-images/62383/62383025ddcabd46b1cd88182732e6b31ec65398" alt="Screen Shot 2019-02-09 at 21.08.37.png"
###■指定したオブジェクトデータ列の項目を表示
df["Embarked"].unique()
data:image/s3,"s3://crabby-images/7c182/7c18287f55acb19d7b116652dfc8eabd7771acdb" alt="Screen Shot 2019-02-09 at 22.09.30.png"
###■指定したオブジェクトデータ列の項目別の数量を表示
df['Embarked'].value_counts()
data:image/s3,"s3://crabby-images/e5f4f/e5f4fe9a1340801f23d77e18380c9cfc2a92779a" alt="Screen Shot 2019-02-09 at 22.05.56.png"
###■グループバイによる集計
- 性別('Sex')ごとに各変数の平均値(mean)を出力
df.groupby('Sex').mean()
data:image/s3,"s3://crabby-images/4cbea/4cbead4f7a780046122fcc232bc5a64729952567" alt="Screen Shot 2019-02-09 at 22.00.23.png"
###■ピボットによる集計
- 性別('Sex')をインデックス、乗船場所('Embarked')をカラムとした、生存者('Survived')の合計(sum)の表を出力
df.pivot_table(values='Survived', index='Sex', columns='Embarked', aggfunc='sum')
data:image/s3,"s3://crabby-images/9b5b2/9b5b28f485a26d6b343a2ad3e1c3ec3a8500e43e" alt="Screen Shot 2019-02-09 at 23.49.29.png"
通常の分析では、ここからさらにグラフを活用しデータの構造をビジュアルで把握していきます。
その際の手法は下記リンク先の別記事でまとめておりますのでご覧ください。
https://qiita.com/ryo111/items/bf24c8cf508ad90cfe2e
その他、欠損値処理のまとめ記事もよろしければご覧ください。
https://qiita.com/ryo111/items/4177c732cc9801bccb17