国科大数据挖掘实训——数据预处理之数据清洗

  1. import numpy as np
  2. import pandas as pd
  3. #读取数据
  4. df=pd.read_csv('/data/workspace/myshixun/step1/train.csv')
  5. ##### begin #####
  6. #查看列中是否存在空值
  7. temp=df.isnull().any()
  8. print(temp)
  9. #使用SimpleImputer取出缺失值所在列的数值,sklearn当中特征矩阵必须是二维才能传入 使用reshape(-1,1)升维
  10. age=df['Age'].values.reshape(-1,1)
  11. #导入模块
  12. from sklearn.impute import SimpleImputer
  13. #实例化,均值填充,可改变strategy参数,实现其他填充方式
  14. imp_mean=SimpleImputer(missing_values=np.nan,strategy='mean')
  15. #fit_transform一步完成调取结果
  16. imp_mean=imp_mean.fit_transform(age)
  17. #填充好的数据传回到 data['Age']列
  18. df_fillna=df
  19. df_fillna['Age']=imp_mean
  20. #检验是否还有空值,为0即说明空值均已被填充
  21. print(df_fillna['Age'].isnull().sum())
  22. ##### end #####
  23. imp_mean=SimpleImputer(missing_values=np.nan,strategy='mean')
  24. imp_mean=imp_mean.fit_transform(age)
  25. df_fillna=df
  26. df_fillna['Age']=imp_mean
  27. #正太分布离群点检测
  28. ##### begin #####
  29. #计算均值
  30. u=df['Age'].mean()
  31. #计算标准差
  32. std=df['Age'].std()
  33. #识别异常值
  34. error = df[np.abs(df['Age'] - u) > 3 * std ]
  35. ##### end #####
  36. print(error)

你可能感兴趣的:(python,机器学习,开发语言)