python数据预处理之将类别数据转换为数值的方法


Posted in Python onJuly 05, 2017

在进行python数据分析的时候,首先要进行数据预处理。

有时候不得不处理一些非数值类别的数据,嗯, 今天要说的就是面对这些数据该如何处理。

目前了解到的大概有三种方法:

1,通过LabelEncoder来进行快速的转换;

2,通过mapping方式,将类别映射为数值。不过这种方法适用范围有限;

3,通过get_dummies方法来转换。

import pandas as pd
from io import StringIO

csv_data = '''A,B,C,D
1,2,3,4
5,6,,8
0,11,12,'''

df = pd.read_csv(StringIO(csv_data))
print(df)
#统计为空的数目
print(df.isnull().sum())
print(df.values)

#丢弃空的
print(df.dropna())
print('after', df)
from sklearn.preprocessing import Imputer
# axis=0 列  axis = 1 行
imr = Imputer(missing_values='NaN', strategy='mean', axis=0)
imr.fit(df) # fit 构建得到数据
imputed_data = imr.transform(df.values) #transform 将数据进行填充
print(imputed_data)

df = pd.DataFrame([['green', 'M', 10.1, 'class1'],
          ['red', 'L', 13.5, 'class2'],
          ['blue', 'XL', 15.3, 'class1']])
df.columns =['color', 'size', 'price', 'classlabel']
print(df)

size_mapping = {'XL':3, 'L':2, 'M':1}
df['size'] = df['size'].map(size_mapping)
print(df)

## 遍历Series
for idx, label in enumerate(df['classlabel']):
  print(idx, label)

#1, 利用LabelEncoder类快速编码,但此时对color并不适合,
#看起来,好像是有大小的
from sklearn.preprocessing import LabelEncoder
class_le = LabelEncoder()
color_le = LabelEncoder()
df['classlabel'] = class_le.fit_transform(df['classlabel'].values)
#df['color'] = color_le.fit_transform(df['color'].values)
print(df)

#2, 映射字典将类标转换为整数
import numpy as np
class_mapping = {label: idx for idx, label in enumerate(np.unique(df['classlabel']))}
df['classlabel'] = df['classlabel'].map(class_mapping)
print('2,', df)


#3,处理1不适用的
#利用创建一个新的虚拟特征
from sklearn.preprocessing import OneHotEncoder
pf = pd.get_dummies(df[['color']])
df = pd.concat([df, pf], axis=1)
df.drop(['color'], axis=1, inplace=True)
print(df)

以上这篇python数据预处理之将类别数据转换为数值的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现ftp客户端示例分享
Feb 17 Python
Python动态导入模块的方法实例分析
Jun 28 Python
如何用Python实现简单的Markdown转换器
Jul 16 Python
详解Django-restframework 之频率源码分析
Feb 27 Python
Python合并同一个文件夹下所有PDF文件的方法
Mar 11 Python
python pytest进阶之fixture详解
Jun 27 Python
解决Python中pandas读取*.csv文件出现编码问题
Jul 12 Python
Python企业编码生成系统之主程序模块设计详解
Jul 26 Python
pytorch torch.nn.AdaptiveAvgPool2d()自适应平均池化函数详解
Jan 03 Python
Python字符串格式化f-string多种功能实现
May 07 Python
Python脚本如何在bilibili中查找弹幕发送者
Jun 04 Python
Python数据类型最全知识总结
May 31 Python
利用Python3分析sitemap.xml并抓取导出全站链接详解
Jul 04 #Python
在django中使用自定义标签实现分页功能
Jul 04 #Python
详解django中自定义标签和过滤器
Jul 03 #Python
pygame实现弹力球及其变速效果
Jul 03 #Python
[原创]使用豆瓣提供的国内pypi源
Jul 02 #Python
python中安装Scrapy模块依赖包汇总
Jul 02 #Python
Python使用filetype精确判断文件类型
Jul 02 #Python
You might like
php字符串截取的简单方法
2013/07/04 PHP
YII路径的用法总结
2014/07/09 PHP
54个提高PHP程序运行效率的方法
2015/07/19 PHP
Symfony2实现在doctrine中内置数据的方法
2016/02/05 PHP
实现PHP框架系列文章(6)mysql数据库方法
2016/03/04 PHP
ThinkPHP中session函数详解
2016/09/14 PHP
php array_walk 对数组中的每个元素应用用户自定义函数详解
2016/11/18 PHP
php 遍历目录,生成目录下每个文件的md5值并写入到结果文件中
2016/12/12 PHP
用正则获取指定路径文件的名称
2007/02/27 Javascript
浅谈JavaScript异常处理语句
2015/06/26 Javascript
JavaScript实现向右伸出的多级网页菜单效果
2015/08/25 Javascript
JavaScript中this详解
2015/09/01 Javascript
Vue制作Todo List网页
2017/04/26 Javascript
validationEngine 表单验证插件使用实例代码
2017/06/15 Javascript
Javascript中toFixed计算错误(依赖银行家舍入法的缺陷)解决方法
2017/08/22 Javascript
phantomjs导出html到pdf的方法总结
2017/10/19 Javascript
微信小程序methods中定义的方法互相调用的实例代码
2018/08/07 Javascript
小程序视频或音频自定义可拖拽进度条的示例代码
2018/09/30 Javascript
利用Angular2的Observables实现交互控制的方法
2018/12/27 Javascript
JS尾递归的实现方法及代码优化技巧
2019/01/19 Javascript
vue跳转方式(打开新页面)及传参操作示例
2020/01/26 Javascript
[01:04:35]2018DOTA2亚洲邀请赛 4.3 突围赛 Secret vs VG 第一场
2018/04/04 DOTA
Python2.x与Python3.x的区别
2016/01/14 Python
PyTorch上搭建简单神经网络实现回归和分类的示例
2018/04/28 Python
Python检测网络延迟的代码
2018/05/15 Python
Python3实现定时任务的四种方式
2019/06/03 Python
玩具反斗城天猫官方旗舰店:享誉全球的玩具店
2017/10/10 全球购物
新年抽奖获奖感言
2014/03/02 职场文书
房产公证书范本
2014/04/10 职场文书
人事经理岗位职责
2014/04/28 职场文书
升职演讲稿范文
2014/05/23 职场文书
医学生求职自荐书
2014/06/12 职场文书
多媒体教室标语
2014/06/26 职场文书
工人先锋号申报材料
2014/12/29 职场文书
2015年教师节活动总结
2015/03/20 职场文书
安全第一课观后感
2015/06/18 职场文书