我正在观看SuperDataScience的机器学习 A-Z,但是当我在执行以下代码示例时:
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
dataset = pd.read_csv('Data.csv')
X = dataset.iloc[:, :-1].values
from sklearn.impute import SimpleImputer
imputer = SimpleImputer(missing_values=np.nan, strategy='mean')
imputer = imputer.fit(X[:, 1:3])
X[:, 1:3]= imputer.transform(X[:,1:3])
from sklearn.preprocessing import LabelEncoder, OneHotEncoder
labelencoder_X = LabelEncoder()
X[:, 0] = labelencoder_X.fit_transform(X[:, 0])
onehotencoder = OneHotEncoder(categorical_features =[0])
X = onehotencoder.fit_transform(X).toarray()
我收到此警告消息:
/usr/local/lib/python3.5/dist-packages/sklearn/preprocessing/_encoders.py:363:FutureWarning:整数数据的处理将在 0.22 版中更改。目前,类别是根据范围 [0, max(values)] 确定的,而将来它们将根据唯一值确定。如果您想要未来的行为并消除此警告,您可以指定“categories='auto'”。如果您在此 OneHotEncoder 之前使用 LabelEncoder 将类别转换为整数,那么您现在可以直接使用 OneHotEncoder。warnings.warn(msg, FutureWarning) /usr/local/lib/python3.5/dist-packages/sklearn/preprocessing/_encoders.py:385: DeprecationWarning: 'categorical_features' 关键字在 0.20 版中已弃用,将在0.22。您可以改用 ColumnTransformer。"
/usr/local/lib/python3.5/dist-packages/sklearn/preprocessing/_encoders.py:363:FutureWarning:整数数据的处理将在 0.22 版中更改。目前,类别是根据范围 [0, max(values)] 确定的,而将来它们将根据唯一值确定。如果您想要未来的行为并消除此警告,您可以指定“categories='auto'”。如果您在此 OneHotEncoder 之前使用 LabelEncoder 将类别转换为整数,那么您现在可以直接使用 OneHotEncoder。警告。警告(味精,未来警告)
/usr/local/lib/python3.5/dist-packages/sklearn/preprocessing/_encoders.py:385:DeprecationWarning:“categorical_features”关键字在 0.20 版中已弃用,并将在 0.22 版中删除。您可以改用 ColumnTransformer。“改用 ColumnTransformer。”,DeprecationWarning) 我正在阅读 sklearn 网站库中的 ColumnTransfer 我不明白如何修复这些错误消息
样本文件:Data.csv