弃用警告:“categorical_features”关键字在 0.20 版中已弃用

数据挖掘 机器学习 Python scikit-学习
2021-09-25 06:56:56

我正在观看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

4个回答

您可以这样做以摆脱弃用消息

from sklearn.preprocessing import OneHotEncoder
from sklearn.compose import ColumnTransformer

ct = ColumnTransformer(
    [('one_hot_encoder', OneHotEncoder(), [0])],    # The column numbers to be transformed (here is [0] but can be [0, 1, 3])
    remainder='passthrough'                         # Leave the rest of the columns untouched
)

x = np.array(ct.fit_transform(x), dtype=np.float)
# Importing the Libraries
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd

#import dataset
dataset = pd.read_csv("Data.csv")
X = dataset.iloc[:,:-1].values
Y = dataset.iloc[:,3].values

#Taking care of Missing data
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])

#Encoding Categorical data
from sklearn.preprocessing import LabelEncoder, OneHotEncoder
from sklearn.compose import ColumnTransformer
labelencoder_X = LabelEncoder()
X[:, 0] = labelencoder_X.fit_transform(X[:, 0])
transformer = ColumnTransformer([('one_hot_encoder', OneHotEncoder(), [0])],remainder='passthrough')
X = np.array(transformer.fit_transform(X), dtype=np.float)
labelencoder_Y = LabelEncoder()
Y = labelencoder_Y.fit_transform(Y)

目前,您无需执行任何操作。即使出现这些警告,代码也应该可以工作。从技术上讲,它们不是错误。

如果您想基于此示例构建一些模型,您可能应该解决它们。您需要的大部分信息都在警告中。例如:

In case you used a LabelEncoder before this OneHotEncoder to convert the categories to integers, then you can now use the OneHotEncoder directly.

因此,当您迁移到sklearn0.22 版时,您不需要同时使用LabelEncoder()OneHotEncoder(),您可以在 中完成所有操作OneHotEncoder(),但您可能需要查看特定于版本的文档以了解如何执行此操作并满足您的特定需求版本发布时需要。

暂时不要做任何事。

用于ColumnTransformer Example 的文档进行 检查。# TODO: 创建一个 LabelEncoder 对象并将其拟合到 X 中的每个特征

# import preprocessing from sklearn
from sklearn import preprocessing
# 1. INSTANTIATE
# encode labels with value between 0 and n_classes-1.
le = preprocessing.LabelEncoder()
# 2/3. FIT AND TRANSFORM
# use df.apply() to apply le.fit_transform to all columns
X_2 = X.apply(le.fit_transform)
X_2.head()

如果您希望查看端到端示例,请查看