获取有效数据

  • Scikit-learn will not accept categorical features by default

    API里面不知使用默认的特征变量名,因此需要编码

    这里我还是有疑问?

    对于下载的数据集,一般的特征变量名,在进行分类的时候,机器是不能识别的,需要对特征名进行编码,因为计算机是二进制语言啊?

  • Need to encode categorical features numerically

  • Convert to ‘dummy variables’

    • 0: Observation was NOT that category
    • 1: Observation was that category

Dealing with categorical features in Python

两种方式是一样的

  • scikit-learn: OneHotEncoder()
  • pandas: get_dummies()

pd.get_dummies

  • 离散特征编码
  • 可用来表示分类变量、非数量因素可能产生的影响

    pandas加入虚拟变量的方式

    get_dummies 是利用pandas实现one hot encode的方式。详细参数请查看官方文档
  1. pandas.get_dummies(data, prefix=None, prefix_sep='_', dummy_na=False, columns=None, sparse=False, drop_first=False)[source]
  • data   要处理的DataFrame
  • prefix 列名的前缀,在多个列有相同的离散项时候使用
  • prefix_sep 前缀和离散值的分隔符,默认为下划线,默认即可
  • dummy_na 是否把NA值,作为一个离散值进行处理,默认为不处理
  • columns 要处理的列名,如果不指定该列,那么默认处理所有列
  • drop_first 是否从备选项中删除第一个,建模的时候为避免共线性使用

Pandas中的get_dummy()函数是将拥有不同值的变量转换为0/1数值。

举例说明:一群样本的年龄分别为19,32,56,94岁,19岁用1表示,32岁用2表示,56岁用3表示,94岁用4表示。1,2,3,4这些数值的大小本身没有意义,只是用来区分年龄。因此在实际问题中,需要将1,2,3,4转化为0/1,即如果是19岁,则为0,若不是则为1,以此类推。

  • 举个例子
  1. import pandas as pd
  2. df = pd.DataFrame([
  3. ['green' , 'm'],
  4. ['red' , 'n'],
  5. ['blue' , 'q']])
  6. df.columns = ['color', 'class']
  7. pd.get_dummies(df)

  1. # Create dummy variables: df_region
  2. df_region = pd.get_dummies(df)
  3. # Print the columns of df_region
  4. print(df_region.columns)
  5. # Drop 'Region_America' from df_region
  6. df_region = pd.get_dummies(df, drop_first=True)
  7. # Print the new columns of df_region
  8. print(df_region)

处理缺失数据

Imputer()

  • 填补缺失值:
  1. sklearn.preprocessing.Imputer(missing_values=’NaN’, strategy=’mean’, axis=0, verbose=0, copy=True)

主要参数说明:

  • missing_values:缺失值,可以为整数或NaN(缺失值numpy.nan用字符串‘NaN’表示),默认为NaN

  • strategy:替换策略,字符串,默认用均值‘mean’替换

    • 若为mean时,用特征列的均值替换
    • 若为median时,用特征列的中位数替换
    • 若为most_frequent时,用特征列的众数替换
  • axis:指定轴数,默认axis=0代表列,axis=1代表行

  • copy:设置为True代表不在原数据集上修改,设置为False时,就地修改,存在如下情况时,即使设置为False时,也不会就地修改

    • X不是浮点值数组
    • X是稀疏且missing_values=0
    • axis=0且X为CRS矩阵
    • axis=1且X为CSC矩阵
  • statistics_属性:axis设置为0时,每个特征的填充值数组,axis=1时,报没有该属性错误

    参考

  1. # Import the Imputer module
  2. from sklearn.preprocessing import Imputer
  3. from sklearn.svm import SVC
  4. # Setup the Imputation transformer: imp
  5. imp = Imputer(missing_values='NaN', strategy='most_frequent', axis=0)
  6. # Instantiate the SVC classifier: clf
  7. clf = SVC()
  8. # Setup the pipeline with the required steps: steps
  9. steps = [('imputation', imp),
  10. ('SVM', clf)]

dropna()

直接删除缺失值

pipline

官方文档

连接多个转换器和预测器在一起,形成一个机器学习工作流,这句解释太官方了,因此我没懂

processing data的更多相关文章

  1. PatentTips - Data Plane Packet Processing Tool Chain

    BACKGROUND The present disclosure relates generally to systems and methods for providing a data plan ...

  2. Becoming a Data Scientist – Curriculum via Metromap

    From: http://nirvacana.com/thoughts/becoming-a-data-scientist/ Data Science, Machine Learning, Big D ...

  3. Monitoring and Tuning the Linux Networking Stack: Receiving Data

    http://blog.packagecloud.io/eng/2016/06/22/monitoring-tuning-linux-networking-stack-receiving-data/ ...

  4. 基于Processing的数据可视化

    虽然数据可视化领域有很多成熟.界面友好.功能强大的软件产品(例如Tableau.VIDI.NodeXL等),但是借助Processing我们可以基于Java语言框架进行丰富多元的可视化编程,熟悉了Pr ...

  5. Awesome Big Data List

    https://github.com/onurakpolat/awesome-bigdata A curated list of awesome big data frameworks, resour ...

  6. IAB303 Data Analytics Assessment Task

    Assessment TaskIAB303 Data Analyticsfor Business InsightSemester I 2019Assessment 2 – Data Analytics ...

  7. Python - 2. Built-in Collection Data Types

    From: http://interactivepython.org/courselib/static/pythonds/Introduction/GettingStartedwithData.htm ...

  8. Stream processing with Apache Flink and Minio

    转自:https://blog.minio.io/stream-processing-with-apache-flink-and-minio-10da85590787 Modern technolog ...

  9. [Windows Azure] Data Management and Business Analytics

    http://www.windowsazure.com/en-us/develop/net/fundamentals/cloud-storage/ Managing and analyzing dat ...

随机推荐

  1. 数据结构与算法的实现(c++)之第一天

    开发工具:codeblocks 17.12版本 学习视频来自b站 第一天:学习swap交换.冒泡排序 swap交换:swap是几乎所有的排序的最基础部分,代码如下: #include <iost ...

  2. QTableWidget中添加列表并输出

    注意:这只是一个demo,项目中用到利用QTableWidget创建表,表中包含各种控件,最后保存表中的内容到doc中,此demo完成了QTableWidget中表的创建,以及将表中内容转为字符串格式 ...

  3. LwIP的udp学习笔记

    * Bind an UDP PCB. * * @param pcb UDP PCB to be bound with a local address ipaddr and port. * @param ...

  4. Linux的那些事-系统启动(增加开机启动项)

    1   /etc/init.d 2   /etc/inittab 3   /etc/rc.d/init.d  1.   /etc/init.d 是一般开机的启动服务存放在这个目录下,至于实现机制,其实 ...

  5. H5浏览器强制手机横屏

    H5强制手机横屏 1. 通过screen.orientation可以定义手机屏幕的方向,但是lock()方法仅在浏览器已经通过requestFullscreen()切换到全屏模式时起作用,例:强制手机 ...

  6. Rust学习--变量

    0x0 每种编程语言都有变量的概念,我们可以把变量理解为最简单的存储方式,它是编码过程中是必不可少的. Rust的变量很有特色.变量不可变的特性让人想起了Erlang.以及后面的模式匹配,我觉得作者应 ...

  7. CSS选择器有哪些?选择器的优先级如何排序?

    CSS选择器分类: CSS的选择器分类可以分为三大类:id选择器,类选择器,标签选择器. 用法如下: 选择器   e.g. 说明 id选择器 #id #header 选择id="header ...

  8. 子组件获取父组件数据 propsDown, 父组件获取子组件数据 eventUp

    (一) popsDowm 三种方法获取父组件数据:被动获得(1):主动获取(2). 1.被动获得: 父组件:v-bind: 绑定变量参数和方法参数:子组件:props 接收参数.可以在模板中直接使用也 ...

  9. jQuery的动画以及扩展功能

    动画DOM及CSS操作 自定义动画 animate(最终css状态,时间) 这个最终css状态是一个对象 <!DOCTYPE html> <html lang="en&qu ...

  10. Hadoop架构及集群

    Hadoop是一个由Apache基金会所开发的分布式基础架构,Hadoop的框架最核心的设计就是:HDFS和MapReduce.HDFS为海量的数据提供了存储,而MapReduce则为海量的数据提供了 ...