2

我已经使用过Decision Tree Classifier并且我想输入 myinput作为string而不是给出一个integer 值,但它给了我error这样的信息:

Traceback (most recent call last):
  File "D:/backup code for odoo project/New folder/New folder/main.py", line 38, in <module>
    theme_res = lebel_encoder.transform(theme_input)
  File "C:\Users\Dell\AppData\Local\Programs\Python\Python38\lib\site-packages\sklearn\preprocessing\_label.py", line 277, in transform
    _, y = _encode(y, uniques=self.classes_, encode=True)
  File "C:\Users\Dell\AppData\Local\Programs\Python\Python38\lib\site-packages\sklearn\preprocessing\_label.py", line 121, in _encode
    return _encode_numpy(values, uniques, encode,
  File "C:\Users\Dell\AppData\Local\Programs\Python\Python38\lib\site-packages\sklearn\preprocessing\_label.py", line 50, in _encode_numpy
    raise ValueError("y contains previously unseen labels: %s"
ValueError: y contains previously unseen labels: ['Food', 'cafe', 'sticky'] 

代码:

import pandas as pd
from sklearn.preprocessing import LabelEncoder
from sklearn import tree
df = pd.read_csv("new_data.csv", encoding='latin1')

inputs = df.drop('selected_theme', axis='columns')
target = df['selected_theme']

lebel_encoder = LabelEncoder()

inputs['main_cat_n'] = lebel_encoder.fit_transform(inputs['main_cat'])
inputs['sub_cat_n'] = lebel_encoder.fit_transform(inputs['sub_cat'])
inputs['nav_bar_n'] = lebel_encoder.fit_transform(inputs['nav_bar'])

inputs_n = inputs.drop(['main_cat', 'sub_cat', 'nav_bar'], axis='columns')

 model = tree.DecisionTreeClassifier()
 model.fit(inputs_n, target)
 print(model.score(inputs_n, target))

 theme_input = ['Food', 'cafe', 'sticky']
 theme_res = lebel_encoder.transform(theme_input)
 result_theme = model.predict(theme_res)
 print(result_theme)
4

1 回答 1

4

错误发生分类器之前,它发生在这一行

 theme_res = lebel_encoder.transform(theme_input)

错误消息告诉您,您label_encoder从未见过“食物”、“咖啡馆”、“粘性”等类别。发生这种情况是因为您重写了 LabelEncoders。您应该为不同的功能使用单独的 LabelEncoders,例如:

categorical_features = ['main_cat', 'sub_cat', 'nav_bar']
encoders = dict()
for cat in categorical_features:
    encoders[cat] = LabelEncoder()
    inputs[f'{cat}_n'] = encoders[cat].fit_transform(inputs[cat])

inputs_n = inputs.drop(['main_cat', 'sub_cat', 'nav_bar'], axis='columns')
...
于 2021-02-27T13:21:43.127 回答