python数据预处理:补充缺失数据,划分训练集和测试集

  1. 算法处理的是数据,不是字符串,也不是布尔值True或者False。

  2. 不可以删除数据。可以求平均值

  3. 对于字符串类型以及布尔类型的分类数据。需要转换成0,1,2这样的数字索引。

1. 导入数据,划分自变量、因变量,补充缺失值


import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
dataset=pd.read_csv('Data2.csv')

X=dataset.iloc[:,:-1].values# 取每一行的前3列
y=dataset.iloc[:,3].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])```

使用数据如下:

Country Age Salary Purchased
0 France 44.0 72000.0 No
1 Spain 27.0 48000.0 Yes
2 Germany 30.0 54000.0 No
3 Spain 38.0 61000.0 No
4 Germany 40.0 NaN Yes
5 France 35.0 58000.0 Yes
6 Spain NaN 52000.0 No
7 France 48.0 79000.0 Yes
8 Germany 50.0 83000.0 No
9 France 37.0 67000.0 Yes

2. 字符串编码成数字或onehot

直接对字符编码成1,2,3的缺点

本来平等的字符串,变成1,2,3之后,好像有先后或者大小顺序了。这不太好,所以要用onehot编码。

#直接编码成数字
from sklearn.preprocessing import LabelEncoder
labelencoder_y=LabelEncoder()
y=labelencoder_y.fit_transform(y)

labelencoder_X=LabelEncoder()
X[:,0]=labelencoder_X.fit_transform(X[:,0])

# 改成onehot编码,只对第一列就可以
#onehot编码
from sklearn.preprocessing import OneHotEncoder
from sklearn.compose import ColumnTransformer
onehotencoder = ColumnTransformer([('encoder', OneHotEncoder(), [0])], remainder = 'passthrough')

X = onehotencoder.fit_transform(X)

3. 划分训练集与测试集

#from sklearn.cross_validation import train_test_split
from sklearn.model_selection import train_test_split
X_train,X_test,y_train,y_test=train_test_split(X,y,test_size=0.2,random_state=0)

4. 特征缩放

避免因为数据量级的不同导致不同特征对结果的影响不同。
特征缩放有两种方式:

  1. 标准化
  2. 归一化
    标准化:

在这里插入图片描述
归一化
在这里插入图片描述

#工资比年龄的数字大,所以需要进行特征缩放
from sklearn.preprocessing import StandardScaler

standardScaler=StandardScaler()
X_train=standardScaler.fit_transform(X_train)
X_test=standardScaler.transform(X_test)

步骤回顾

  1. pandas导入数据
  2. 自变量和因变量分离
  3. 缺失值处理
  4. 字符串变成数字
  5. 划分训练集和测试集
  6. 特征缩放

注意事项总结:

  1. 不能有数据缺失的情况
  2. 所有分类类型的数据变成数字类型的数据
  3. 特征缩放。算法不能知道哪个特征更重要,不能让某个特征主导了计算结果。应该让不同的特征无差别地影响结果

预处理的好处是能够更快地收敛,更接近真实的结果,会极大地减少训练的时间,提升预测的准确度。

  • 2
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杰米的大鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值