データフレームの中がリストになってしまったり、区切りになってしまうことがある際に、それを別のカラムに分解する方法を備忘録的にまとめておきます。よかったら試してみてください。
データフレームの中がリスト→区切りに変換
import pandas as pd
df = pd.DataFrame(
{'col_1': [["A","B","C"],["D","E","F"],["G","H","I"]]},
index=[1, 2, 3])
df
data:image/s3,"s3://crabby-images/9fe49/9fe4950ac54d8fe2148adf3c27afea511a8f141f" alt=""
#いったんリストをカンマ区切りに変更するための関数
#map関数を用いて全部の行に適用させる
def list_out(x):
return ','.join(x)
df["col_1"]=df["col_1"].map(list_out)
df
data:image/s3,"s3://crabby-images/6c7e3/6c7e394c6593c70e73e845601fa80415744af49a" alt=""
データフレームの中が区切り→別のカラムに分解する
expand=Trueを指定することで、分解することができます。(.str.は必須)
df['col_1'].str.split(',',expand=True)
data:image/s3,"s3://crabby-images/6f099/6f09952cbd8751db3d622eb2c587f77929733a83" alt=""
”str.split(‘区切り文字(,や/など)’,expand=True)”を使うことで簡単に区切りから別のカラムに分解することができます。ぜひ使ってみてください。
(参考)別パターン
df = pd.DataFrame(
{'col_0':[1,2,3],
'col_1': [["A","B","C"],["D","E","F"],["G","H","I"]]},
index=[1, 2, 3])
df
data:image/s3,"s3://crabby-images/25884/25884c52c6ef861d0b20afa9b6191bfb0fdc2778" alt=""
上記のような場合を、リストの要素ごとで縦に分解するイメージのものが以下のコードになっています。
df.explode("col_1", ignore_index=False)
data:image/s3,"s3://crabby-images/274ac/274acd6216bf8277dd433250a1abc138d854ad76" alt=""
このような展開のやり方もありますので是非お試しを!!
コメント