【发布时间】:2019-07-17 01:51:08
【问题描述】:
请放轻松。我正在将职业转向数据科学,并且没有 CS 或编程背景——所以我可能会做一些非常愚蠢的事情。我研究了几个小时都没有成功。
目标:让 Pipeline 与 OrdinalEncoder 一起运行。
问题:代码无法通过 OrdinalEncoder 调用运行。它确实在没有 OrdinalEncoder 的情况下运行。据我所知,我可以传递两个参数,即 categories 和 dtype。都没有帮助。
我将公共diabetes data 设置传递给模型。这是问题吗? IOW,将高基数特征传递给 OrdinalEncoder 是否会在模型构建后导致训练/测试数据之间出现问题,即测试拆分具有训练集没有的值?
from sklearn.pipeline import Pipeline
from sklearn.impute import SimpleImputer
from sklearn.preprocessing import OrdinalEncoder
from sklearn.ensemble import RandomForestClassifier
pipe = Pipeline([
('imputer', SimpleImputer()),
('ordinal_encoder', OrdinalEncoder()),
('classifier', RandomForestClassifier(criterion='gini', n_estimators=100))])
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2)
# Construct model
model = pipe.fit(X_train, y_train)
# Show results
print("Hold-out AUC score: %.3f" %roc_auc_score(model.predict_proba(X_test),y_test))
这是我得到的错误:
ValueError: Found unknown categories [17.0] in column 0 during transform
我做错了什么?
设置:
The scikit-learn version is 0.20.2.
3.7.2 (v3.7.2:9a3ffc0492, Dec 24 2018, 02:44:43)
[Clang 6.0 (clang-600.0.57)]
sys.version_info(major=3, minor=7, micro=2, releaselevel='final', serial=0)
【问题讨论】:
标签: python-3.x scikit-learn pipeline valueerror ordinal