ile*_*l42 3 python pandas scikit-learn one-hot-encoding
实际上,我的问题是基于:
所以,数据应该是:
import pandas as pd
import io
t="""
AV4MdG6Ihowv-SKBN_nB DTP,FOOD
AV4Mc2vNhowv-SKBN_Rn Cash 1,FOOD
AV4MeisikOpWpLdepWy6 DTP,Bar
AV4MeRh6howv-SKBOBOn Cash 1,FOOD
AV4Mezwchowv-SKBOB_S DTOT,Bar
AV4MeB7yhowv-SKBOA5b DTP,Bar
"""
data_vec=pd.read_csv(io.StringIO(t),sep='\s{2,}',names=['id','source'])
data_vec
Run Code Online (Sandbox Code Playgroud)
这是data_vec:
id source
0 AV4MdG6Ihowv-SKBN_nB DTP,FOOD
1 AV4Mc2vNhowv-SKBN_Rn Cash 1,FOOD
2 AV4MeisikOpWpLdepWy6 DTP,Bar
3 AV4MeRh6howv-SKBOBOn Cash 1,FOOD
4 AV4Mezwchowv-SKBOB_S DTOT,Bar
5 AV4MeB7yhowv-SKBOA5b DTP,Bar
Run Code Online (Sandbox Code Playgroud)
如果我想要结果如下:(这意味着如何矢量化多个标签或类别?)
_id source_Cash 1 source_DTOT source_DTP Food Bar
0 AV4MdG6Ihowv-SKBN_nB 0 0 1 1 0
1 AV4Mc2vNhowv-SKBN_Rn 1 0 0 1 0
2 AV4MeisikOpWpLdepWy6 0 0 1 0 1
3 AV4MeRh6howv-SKBOBOn 1 0 0 1 0
4 AV4Mezwchowv-SKBOB_S 0 1 0 0 1
5 AV4MeB7yhowv-SKBOA5b 0 0 1 0 1
Run Code Online (Sandbox Code Playgroud)
如果它是重复的,警告我删除!
阿位str.split和pd.get_dummies魔法,由斯科特·波士顿的启发和提高(从原始版本)由于强尼.
df = df.set_index('id').source.str.get_dummies(',')
df.columns = df.columns.str.split().str[0].str.lower()
df = df.add_prefix('source_').reset_index()
print(df)
id source_bar source_cash source_dtot source_dtp \
0 AV4MdG6Ihowv-SKBN_nB 0 0 0 1
1 AV4Mc2vNhowv-SKBN_Rn 0 1 0 0
2 AV4MeisikOpWpLdepWy6 1 0 0 1
3 AV4MeRh6howv-SKBOBOn 0 1 0 0
4 AV4Mezwchowv-SKBOB_S 1 0 1 0
5 AV4MeB7yhowv-SKBOA5b 1 0 0 1
source_food
0 1
1 1
2 0
3 1
4 0
5 0
Run Code Online (Sandbox Code Playgroud)