# F: P, ^7 D+ A" V$ s 为什么要进行数据预处理?
8 t" ~# e9 s1 y0 B$ O) K' G
因为原始数据往往是不完整的,含有噪声的以及不一致的,采用这些数据进行机器学习往往得到的结果是不准确的。所谓不完整是指缺少相应的属性值;含有噪声是指数据中存在错误的、异常的数据;而不一致的数据是指数据中可能存在在编码上或者命名上的差异重复。
3 Y9 Y+ R- Y+ E 
3 A" {/ d0 q2 W/ L
如何进行数据预处理?
+ N5 x' r, H5 I/ V# C! f' \ 数据预处理主要包括以下步骤:数据清洗,数据集成,数据规约以及数据变换
8 |, ~/ \" |' L. f2 v0 s 
- |0 ]9 p5 f( _! [: Z 一、数据清洗:
; \. l3 J6 d! S( f# Z (1) 数据清洗的目的:消除错误、冗余和数据噪音。
7 f: {% x& d S& C7 g' r
(2) 数据清洗过程需要满足的条件:
. \& K8 N+ Y. r8 z6 Q* e: s
1、不论是单数据源还是多数据源,都要检测并且除去数据中所有明显的错误和不一致。
+ X7 s0 N) K3 P% J5 J
2、尽可能地减小人工干预和用户的编程工作量,而且要容易扩展到其他数据源。
2 l. `, @ l3 N, h: Q 3、应该和数据转化相结合。
) X! b" M- ? i+ ~; B1 D
4、要有相应的描述语言来指定数据转化和数据清洗操作。
# R( p8 Y7 ^( W 异常数据的清洗过程主要分为以下6个步骤:
3 y: c' l( B$ R 1、元素化:将非标准的数据,统一格式化成结构数据。
! X9 A7 ~2 c1 a b2 X8 l
2、标准化:将元素标准化,根据字典消除不一致的缩写等等。
* V- [ J7 B, S1 K) I% V" Q( _ 3、校验:对标准化的元素进行一致性校验,即在内容上修改错误。
& X" r7 b" s$ L! f 4、匹配:在其它记录中寻找相似的记录,发现重复异常。
% `, |$ ^" A) ]2 Q5 u, e
5、消除重复记录:根据匹配结果进行处理,可以删除部分记录或者多个记录合并为一个更完整信息的记录。
. a( T( `2 R2 j+ a! S7 H# F9 I! ] 6、档案化(documenting):将前5个步骤的结果写入元数据存储中心。这样可以更好地进行后续的清理过程,使得用户容易理解数据库以及更好地进行切片、切块等操作。
) f) }' ^, A# W4 V 
& h) i/ ?2 \5 i1 i' I6 M5 h( t7 G
几种发现数据异常的方法:
. q1 n" F& W3 Y9 U t
1. 基于契比雪夫定理的统计学方法:这种方法可以随机选取样本数据进行分析,加快了检测速度,但是这是以牺牲准确性为代价的。
& N. K( A& X/ u0 n& u0 }
2. 模式识别的方法:基于数据挖掘和机器学习算法来查找异常数据,主要牵涉关联规则算法。
. R5 s5 K. s; M! q0 b0 N 3. 基于距离的聚类方法(聚类分析是一种新兴的多元统计方法,是当代分类学与多元分析的结合。聚类分析是将分类对象置于一个多维空间中,按照它们空间关系的亲疏程度进行分类。通俗的讲,聚类分析就是根据事物彼此不同的属性进行辨认,将具有相似属性的事物聚为一类,使得同一类的事物具有高度的相似性。):这也是数据挖掘中的算法,重点在于它的类的评测标准为Edit距离,来发现数据集中的重复纪录。
. E9 [; l1 D6 Y2 b3 J8 E" Q
4. 增量式的方法:如果数据源允许,我们可以采取随机的方法获取元组。这允许给异常检测算法一个随机元组流的输入。一些异常检测算法对这种输入可以使用增量、统计学方式,可以发现更多的异常。从数据源中获得元组,然后转换之后作为异常检测算法的输入。
* r9 e0 |: ~: v- W% l L 二、数据集成:
" q" b, ?9 l* G" p% i& x
数据集成的目的:将数据由多个数据源合并成一个一致的数据存储,如数据仓库。该部分主要涉及数据的选择、数据的冲突问题以及不一致数据的处理问题。
1 O0 k& ]( J; t4 v 三、数据归约:
# @! I4 o3 A) ]5 B 数据归约的目的:是指在对发现任务和数据本身内容理解的基础上,寻找依赖于发现目标的表达数据的有用特征,以缩减数据模型,从而在尽可能保持数据原貌的前提下最大限度的精简数据量。简单的说就是压缩数据。
p {( G2 e" E9 r$ Z& { 数据归约的方法:可以通过如聚集、删除冗余特征或聚类来压缩数据的规模。
* Q+ H) \2 T) h6 t s- Z
1.数据立方体聚集:把聚集的方法用于数据立方体。
6 |, ?/ Z. y: W# a p 2.维归约:检测并删除不相关、弱相关或冗余属性。
5 H9 s. \' V, f, G3 v, I
3.数据压缩:选择正确的编码压缩数据集。
; V! C0 c& B3 i2 x: s7 m6 k 4.数值压缩:用较小的数据表示数据,或采用较短的数据单位,或者用数据模型代表数据。
+ v/ v! H+ C9 N8 t! z0 _ 5.离散化和概念分层生成:使连续的数据离散化,用确定的有限个区段值代替原始值;概
7 R8 ~1 m; S) V; ^( p5 a( s

& j: R6 I- }# G$ W9 e5 x8 R; v
四、数据变换:是找到数据的特征表示,用维变换或转换来减少有效变量的数目或找到数据的不变式,包括规格化、规约、切换和投影等操作。就是指把原始数据转换成为适合数据挖掘的形式
2 I, y9 X- k1 i& i- p& d
1.光滑:去掉数据的噪声,包括分箱,回归和聚类
) L" Z' [& s( B6 R- ?7 Y2 c5 ]7 z% F
2.聚集:对数据进行汇总或聚集。这一步通常用来为多粒度数据分析构造数据立方体
( r Y3 {4 T/ A( b# j# `
3.数据泛化:使用概念分层,用高层概念替换底层或原始数据。
. c& f0 F# z# N5 @
4.规范化:又称为归一化,指将属性数据按比例缩放,使之落入一个小的特定区间。
% e- L1 t4 d5 m1 u) t+ D: S3 ^

6 F' ?* `% a/ b) @6 z' X
那么运用python如何进行数据预处理呢?其过程主要包括以下6个步骤:导入库、导入数据集、处理缺失数据、解析分类数据、将数据集分为训练集和测试集、特征量化。
4 L8 L1 L* w8 @1 ?/ |% s

0 B+ n& r1 J1 y* ?& L: { [
其代码实现如下:
% `8 a5 N/ e9 T7 E9 n+ A- I6 X

9 P$ S( ?1 s4 v# f% I 以上关于机器学习数据的预处理是在阅读了其它文献资料的基础上总结的,如有错误,希望指正!
" c9 |7 f0 z6 p5 U0 |) r) H2 r% f4 |