这篇博客的主要内容python
经过一些转换函数将特征数据转换成更加适合算法模型的特征数据过程算法
sklearn.preprocessing
特征的单位或者大小相差较大,或者某特征的方差相比其余的特征要大出几个数量级,容易影响(支配)目标结果,使得一些算法没法学习到其它的特征api
经过对原始数据进行变换把数据映射到(默认为[0,1])之间函数
做用于每一列,max为一列的最大值,min为一列的最小值,那么X’’为最终结果,mx,mi分别为指定区间值默认mx为1,mi为0学习
milage,Liters,Consumtime,target 40920,8.326976,0.953952,3 14488,7.153469,1.673904,2 26052,1.441871,0.805124,1 75136,13.147394,0.428964,1 38344,1.669788,0.134296,1
from sklearn.preprocessing import MinMaxScaler import pandas as pd def minmax_demo(): data = pd.read_csv("dating.txt") print(data) # 一、实例化一个转换器类 transfer = MinMaxScaler(feature_range=(2, 3)) # 二、调用fit_transform data = transfer.fit_transform(data[['milage','Liters','Consumtime']]) print("最小值最大值归一化处理的结果:\n", data) return None
经过对原始数据进行变换把数据变换到均值为0,标准差为1范围内code
做用于每一列,mean为平均值,σ为标准差orm
同上归一化介绍中使用的数据get
from sklearn.preprocessing import StandardScaler import pandas as pd def stand_demo(): data = pd.read_csv("dating.txt") print(data) transfer = StandardScaler() data = transfer.fit_transform(data[['milage','Liters','Consumtime']]) print("标准化的结果:\n",data) print("每一列特征的平均值:\n",transfer.mean_) print("每一列特征的方差:\n",transfer.var_) return None