在fit_transform之后获取sklearn.LabelEncoder()映射

问题描述 投票:3回答:1

我正在尝试获取标签编码器的映射,以确定哪些代码为我的df中的列提供了每个字符串。

这是编码代码:

y[:]=LabelEncoder().fit_transform(y[:])

我希望得到这样的输出:

A:1
B:2
C:3

谢谢您的帮助!

python python-3.x scikit-learn
1个回答
2
投票

如果您希望以后能够使用映射或逆变换,则应避免进行内联初始化。

data = ['A', 'A', 'B', 'C', 'B', 'B'] # `y`

le = LabelEncoder()
mapped = le.fit_transform(data)

mapping = dict(zip(le.classes_, range(1, len(le.classes_)+1)))
print(mapping)
# {'A': 1, 'B': 2, 'C': 3}

更好的是,如果要反转编码,请使用inverse_transform

print(le.inverse_transform(mapped))
# ['A' 'A' 'B' 'C' 'B' 'B']
© www.soinside.com 2019 - 2024. All rights reserved.