资讯频道首页 | 社会看点 | 花边杂烩 | 今日阳谷 | 生活服务 | 民俗名胜 | 房产家居 | 车行万里 | 招商加盟 | 娱乐频道 | 阳谷论坛
您所在的位置:阳谷信息港 > 资讯频道 > 花边杂烩

为什么我们需要数据预处理?

发布:2019/3/6 17:14:06  来源:阳谷信息港  浏览次  编辑:佚名  分享/转发»

原标题:为什么我们需要数据预处理?

为什么我们需要数据预处理?

作者 | 邱雅婷

责编| 郭芮

数据挖掘的核心是什么?这个的答案是算法应该没什么疑问。那数据挖掘的基石又是什么呢?那就是今天我们要来说的数据预处理。

什么是数据预处理?

为什么我们需要数据预处理?

数据科学家们一直想为数据预处理赋予一个定义。其实简单地说,数据预处理就是一种数据挖掘技术,本质就是为了将原始数据转换为可以理解的格式或者符合我们挖掘的格式。

为什么需要数据预处理?

在真实世界中,数据通常是不完整的(缺少某些感兴趣的属性值)、不一致的(包含代码或者名称的差异)、极易受到噪声(错误或异常值)的侵扰的。因为数据库太大,而且数据集经常来自多个异种数据源,低质量的数据将导致低质量的挖掘结果。就像一个大厨现在要做美味的蒸鱼,如果不将鱼进行去鳞等处理,一定做不成我们口中美味的鱼。

数据预处理就是解决上面所提到的数据问题的可靠方法。

那它是怎么做到的呢?

就像大厨准备处理鱼的刀具一样,数据预处理也是如此。它准备原始数据以便进一步处理。下面是数据预处理要采取的步骤,如图:

为什么我们需要数据预处理?

数据清洗: 填写缺失的值,光滑噪声数据,识别或删除离群点,并解决不一致性来“清理数据”; 数据集成:使用多个数据库,数据立方体或文件; 数据归约: 用替代的,较小的数据表示形式替换元数据,得到信息内容的损失最小化,方法包括维规约,数量规约和数据压缩; 数据变换:将数据变换成使用挖掘的形式。

下面这张图很形象得把这四个步骤的作用表现出来,挺有意思的。

为什么我们需要数据预处理?

数据预处理任务

应用

是时候采取一些简单的实际应用来了解数据预处理是如何完成的。

下面的例子我们用 Python 来处理,还需要用到两个库,分别是 Numpy、Pandas。

准备数据

在这里,我们有一个数据集,其中包括IT专业人员的信息,比如国家、工资、性别,如下:

为什么我们需要数据预处理?

我们可以随意创建此数据集的副本。

我们可以观察到上面的数据集包含一些空值,这是故意的。后面很快可以看到它发挥的作用

导入库

简单说下 Numpy、Pandas 这两个库的作用:Numpy 库包含数学工具,它可以用于在我们代码中的任何类型的数学;Pandas 库用于导入和管理数据集。

下面是我们导入库的方法:

importpandas aspd

importnumpy asnp

导入数据集

我们已经导入库了,接下来我们需要获取数据集。在我本地里,我将我的数据集文件命名为‘profess',它的格式为.csv。

#读取数据(我的数据集文件跟我的python文件在同一目录下)

data= pd.read_csv( "profess.csv")

导入数据集后,我们输出看下它的格式如何:

print(data)

为什么我们需要数据预处理?

Good!我们成功得将数据集导入测试环境中。

数据清洗——查看缺失值

为了成功管理数据,缺失值的概念很重要。如果工程师没有正确处理缺失值,可能最后得出关于数据的推断是不准确的。我们再来仔细看下我们的数据的缺失值情况,用 Pandas 库的 isnull 函数来看看。

print( data.isnull() .sum())

为什么我们需要数据预处理?

我们可以发现 Age,Salary 列都有缺失值(就是为空的值),缺失值数量都为1。处理缺失值有7种处理方法,我们这里说说比较常用的两种。

1、此方法经常用于处理空值,如果某行有特定特征d的空值,就删除此行。如果特定列具有超过75%的缺失值,就删除特定列。不过我们要在确保样本数据足够多的情况下,采用这个方法。因为我们要确保删除数据后,不会增加偏差。

data.dropna(inplace= True)

print(data.isnull().sum())

为什么我们需要数据预处理?

2、这个方法适用于具有年份或者年龄,金额等数字数据的功能。我们可以计算特征的均值,中值或众数,将其替换为缺失值。与第一种方法相比,这种可以抵消数据的缺失,产生更好的效果。

我们用来看一下操作:

# 将 Age 列中为空的值替换为 Age 的中位数。

# medain()是 pandas 库的求中位数的方法

data[ Age] = data[ Age]

.replace(np.NaN, data[ Age]

.median())

print( data[ Age])

为什么我们需要数据预处理?

我们成功替换掉了。

数据归约

为了满足挖掘需求,我们需要知道这些工程师们的薪水分布区间,但是我们只有‘Salary' 薪水这一列,所以为了方便挖掘,我们给我们的数据集增加‘薪水等级' level 这一列,通过 Salary 列进行区间归约,这种方法叫做“属性构造”。我们看看操作:

#数据归约

defsection(d):

if50000> d:

return"50000以下"

if100000> d >= 5000:

return"50000-100000"

ifd > 100000:

return"100000以上"

data[ level] = data[ Salary]

.apply( lambdax: section(x))

print(data[ level])

为什么我们需要数据预处理?

我们定义一个‘数据变换'的函数给,根据 Salary 判断选择区间进行变换并赋值给 level。

数据变换

我们可以看到 Salary 列也有空值,从业务上理解它应该是数字数值才是。但是我们发现我们的数据集中是货币格式,我们需要对它进行‘数据变换',转换成我们所需的数字格式。来看下实际操作:

#数据变换

def convert_currency(d):

new_value = str(d).replace( ",", "")

.replace( "$", "")

returnfloat(new_value)

data[ Salary] = data[ Salary].apply(convert_currency)

# mean()是 pandas 库的求平均值的方法

data[ Salary] = data[ Salary]

.replace(np.NaN, data[ Salary]

.mean())

print( data[ Salary])

变换成功:

为什么我们需要数据预处理?

我们定义一个“数据变换”的函数,然后将它应用再 Salary 列上,最后同数据清洗那一步同样的替换操作,我们这里用平均值替换。

写在最后

至此我们算走完数据预处理的一个基本流程。

这是比较基础的一个小应用,但是相信我们以后处理数据的时候能有一个基本清晰的解决思路,以及如何选择处理方法以及为什么选择有所了解。

相关文章

网友评论

评论加载中...
推广链接
最新文章快读
一周热门文章推荐

网站首页 | 分类信息 | 企业商圈 | 网上商城 | 你问我答 | Blog | 阳谷论坛

免责声明: 本站所有新闻文章来源于网络,仅代表作者个人观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,对新闻文章以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容!

(特别声明:视频、图文版权属于原作者,如构成侵权,请及时联系我们,会在第一时间删除!删稿请发至邮箱:4143080@qq.com)

Copyright © 2003-2009 www.yanggu.tv All rights reserved.