原创博文,转载请注明出处。

(为了节约空间,打印结果常用“...”表示省略)

一、加载数据集

1. 加载sklearn自带的数据集

scikit-learn有一些自带的标准数据集,例如用于分类的经典数据集iris和digits以及用于回归的boston house prices数据集。

这些自带的数据集一种是类似字典的对象,它保存所有的数据(通常情况下,特征向量存储在.data成员中,在监督学习中,标签存储在.target成员中)和关于数据的元数据(如.target_names成员用来存储各个标签值对应的含义标签名称)。每个数据集中包含的成员不一定是一样的,既然数据集是一种类似字典的对象,那么,我们就可以通过“数据集名.keys()”来查看该数据集中,究竟有哪些成员,从而对数据集有个整体的把握。

from sklearn import datasets
iris = datasets.load_iris()
print iris
{'target_names': array(['setosa', 'versicolor', 'virginica'],
dtype='|S10'), 'data': array([[ 5.1, 3.5, 1.4, 0.2],
[ 4.9, 3. , 1.4, 0.2],
[ 4.7, 3.2, 1.3, 0.2],
...
[ 6.2, 3.4, 5.4, 2.3],
[ 5.9, 3. , 5.1, 1.8]]), 'target': array([0, 0, 0, 0, ···2, 2, 2]), ...}

2. 访问自带数据集成员

载入数据集后,可以通过“数据集名.成员名”的方式访问成员。

访问特征集

print iris.data
[[ 5.1  3.5  1.4  0.2]
[ 4.9 3. 1.4 0.2]
[ 4.7 3.2 1.3 0.2]
...
[ 6.2 3.4 5.4 2.3]
[ 5.9 3. 5.1 1.8]]

访问标签集

print iris.target
[0 0 ... 0 0 0 1 1 ... 1 1 2 2 ... 2 2]

3. 加载数据非二维数组的数据集demo

# _*_ coding:utf-8_*_
from sklearn import datasets
digits = datasets.load_digits()
print digits.keys()
print '------'
# 第0个样本image为
print digits.images[0]
print '------'
print digits.data[0]
['images', 'data', 'target_names', 'DESCR', 'target']
------
[[ 0. 0. 5. 13. 9. 1. 0. 0.]
[ 0. 0. 13. 15. 10. 15. 5. 0.]
[ 0. 3. 15. 2. 0. 11. 8. 0.]
[ 0. 4. 12. 0. 0. 8. 8. 0.]
[ 0. 5. 8. 0. 0. 9. 8. 0.]
[ 0. 4. 11. 0. 1. 12. 7. 0.]
[ 0. 2. 14. 5. 10. 12. 0. 0.]
[ 0. 0. 6. 13. 10. 0. 0. 0.]]
------
[ 0. 0. 5. 13. 9. 1. 0. 0. 0. 0. 13. 15. 10. 15. 5.
0. 0. 3. 15. 2. 0. 11. 8. 0. 0. 4. 12. 0. 0. 8.
8. 0. 0. 5. 8. 0. 0. 9. 8. 0. 0. 4. 11. 0. 1.
12. 7. 0. 0. 2. 14. 5. 10. 12. 0. 0. 0. 0. 6. 13.
10. 0. 0. 0.]

可以看到.images和.data的区别:.data将.images中的元素由二维数组转为一维向量。

4. 加载外部数据

scikit-learn接受numpy array或者scipy稀疏矩阵这样的数值型数据,另外,它也和pandas里的DataFrame是兼容的。

二、拟合分类器

1. 分类器的定义

在scikit-learn中,分类评估器是一种python类,具有fit(X, y)和predict(T)两个方法。

过程是:用训练集fit某个分类器,然后用这个fit好的分类器实例来predict测试集

2. demo:作用在digits数据集上的SVC(分类器)模型的建立

SVC的全称为support vector classification,即:支持向量分类器,svm中定义的python类。

2.1 基础原型

digits数据集共有1797个样本,我们先简单地取第0个到第1759个作为训练集,第1760到第1796个作为测试集

# _*_ coding:utf-8_*_
from sklearn import datasets
from sklearn import svm
clf = svm.SVC()
digits = datasets.load_digits()
X, y = digits.data, digits.target
clf.fit(X[0:1760], y[0:1760]) # 拟合SVC分类器实例 # 对比第1760到1796个实例的预测值和真实值,查看效果
print clf.predict(X[1760:1797]) # 用SVC分类器实例预测测试集
print y[1760:1797]
[1 7 3 3 3 3 1 3 3 5 3 3 3 6 3 3 5 3 3 3 2 3 2 3 5 7 9 3 4 3 3 4 9 3 3 3 3]
[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]

2.2 调参

在new一个分类器实例的时候,可以对分类器的参数进行设置,例如:

将上面的代码中,SVC分类器参数稍做设置

clf = svm.SVC(gamma=0.001, C=100.)

结果对比,预测准确度大大提高(注意第二行是真实值,第一行才是预测值)

[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]
[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]

上面的调参过程是手动完成的,可以使用网格搜索和交叉验证的方法自动找到合适的参数。

三、 模型存储

我们建好模型之后,需要将模型存储起来,以供日后使用。

python内置的pickle模块可以用来存储模型,但是,scikit-learn中还有类似功能的joblib类。它不可以像pickle一样将模型保存到字符串中,但它可以将模型保存在磁盘上,而且大数据应用场景下joblib更高效。

下面我们将上面训练好的模型clf保存在SVC_clf.pkl文件中:

将下面的代码加入上面代码的最后一行

from sklearn.externals import joblib
joblib.dump(clf, 'svc_clf.pkl')

这样,以后需要用到模型只要重新joblib.load该模型即可,也可以在其他python进程中使用。

例如,可以在同一个项目的另一个python文件中,重新导入该模型,进行预测:

from sklearn import datasets
from sklearn import svm
digits = datasets.load_digits()
X, y = digits.data, digits.target from sklearn.externals import joblib
clf = joblib.load('svc_clf.pkl')
print clf.predict(X[1760:1797])
print y[1760:1797]
[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]
[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]

运行结果和之前一样,说明是同一个模型。

ps: pickle是腌黄瓜的意思,dump方法和load方法的命名很生动地表示出了:将模型倒入(dump)腌制容器中,以备日后取出(load)使(食)用。而joblib继承了pickle中两个方法的命名方法。

四 约定

1. 类型转换

*所有输入的类型都会被转化为float64

*回归预测输出转化为float64,分类预测输出不变

2. 更改参数、重新拟合

分类器可以通过.set_params()方法修改超参数,更改后再调用.fit()方法,将重写之前的模型。

例如,将上面代码中,clf拟合后,加入以下代码:

clf.set_params(C=0.01).fit(X,y)

得到:

[1 1 6 3 1 3 3 1 3 3 3 1 3 6 3 3 3 1 1 3 3 3 3 3 3 3 3 3 1 3 3 1 3 0 3 3 3]
[1 7 6 8 4 3 1 4 0 5 3 6 9 6 1 7 5 4 4 7 2 8 2 2 5 7 9 5 4 8 8 4 9 0 8 9 8]

预测结果效果下降很多,说明分类器超参数设置成功,新模型覆盖旧模型。

sklearn快速入门的更多相关文章

  1. sklearn 快速入门教程

    1. 获取数据 1.1 导入sklearn数据集 sklearn中包含了大量的优质的数据集,在你学习机器学习的过程中,你可以通过使用这些数据集实现出不同的模型,从而提高你的动手实践能力,同时这个过程也 ...

  2. scikit-learn——快速入门

    scikit-learn——快速入门 sklearn 快速入门 环境: ubuntu 12.04, 64 bits python 2.7 sklearn 0.14 好几个月没有发博客了,平时的笔记都随 ...

  3. scikit-learn——快速入门 - daniel-D(转)

    ML sklearn快速入门 申明:该系列博客是学习 sklearn 的笔记,内容将涵盖大部分机器学习的方法.本人微博@迅猛龙Daniel,能力有限,存在任何问题,希望共同交流.该博客采用马克飞象专业 ...

  4. [阿里移动推荐算法]比赛_快速入门_4_19_update_仅供参考,思维不要受局限

    [这里只讲快速入门——即破题,正负样本不平衡.特征数量等问题就自己多看论文或者其他资料吧~~如果还有数据挖掘相关基础知识不了解的,建议看看<数据挖掘导论>] [以下是理解错误案例]:错误的 ...

  5. Web Api 入门实战 (快速入门+工具使用+不依赖IIS)

    平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html 屁话我也就不多说了,什么简介的也省了,直接简单概括+demo ...

  6. SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=》提升)

     SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=>提升,5个Demo贯彻全篇,感兴趣的玩才是真的学) 官方demo:http://www.asp.net/si ...

  7. 前端开发小白必学技能—非关系数据库又像关系数据库的MongoDB快速入门命令(2)

    今天给大家道个歉,没有及时更新MongoDB快速入门的下篇,最近有点小忙,在此向博友们致歉.下面我将简单地说一下mongdb的一些基本命令以及我们日常开发过程中的一些问题.mongodb可以为我们提供 ...

  8. 【第三篇】ASP.NET MVC快速入门之安全策略(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  9. 【番外篇】ASP.NET MVC快速入门之免费jQuery控件库(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

随机推荐

  1. Linux下安装maven和nexus

    Linux下安装maven1.首先到Maven官网下载安装文件,目前最新版本为3.0.3,下载文件为apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令: 2.进入下载 ...

  2. 【BZOJ1036】[ZJOI2008] 树的统计Count(一道可怕的模板题:树剖+线段树)

    点此看题面 题解 这真的只是一道模板题:一个树链剖分套上一个线段树(令我窒息的组合). 既然是模板题,那就直接上代码吧. 代码 #include<bits/stdc++.h> #defin ...

  3. 3205: 数组做函数参数--数组元素求和1--C语言

    3205: 数组做函数参数--数组元素求和1--C语言 时间限制: 1 Sec  内存限制: 128 MB提交: 178  解决: 139[提交][状态][讨论版][命题人:smallgyy] 题目描 ...

  4. bazel安装

    https://blog.csdn.net/cxq234843654/article/details/70861155 sudo apt-get install openjdk-8-jdk echo ...

  5. python读取文件指定行

    import linecache file=open('3_2.txt','r') linecount=len(file.readlines()) linecache.getline('3_2.txt ...

  6. MySQL DBA从小白到大神实战

    MySQL5.6 For CentOS 6.6 源码编译安装 o1.关闭防火墙o2.配置sysctl.confo3.检查操作系统上是否安装了MySQLo4.下载mysql源码包o5.添加用户和组o6. ...

  7. 爬虫 xpath etree自动补全页面

    aa = etree.HTML(response.content) bb = etree.tostring(aa) doc = etree.HTML(bb)

  8. c 语言技巧

    位运算 & 位逻辑与 | 位逻辑或 ^ 位逻辑异或 - 位逻辑反 >> 右移 << 左移 通过对数据本身的01编码进行处理,速度稍微快于普通运算符 如,10 / 2 = ...

  9. python爬虫入门八:多进程/多线程

    什么是多线程/多进程 引用虫师的解释: 计算机程序只不过是磁盘中可执行的,二进制(或其它类型)的数据.它们只有在被读取到内存中,被操作系统调用的时候才开始它们的生命期. 进程(有时被称为重量级进程)是 ...

  10. devicemaps_init(mdesc)

    devicemaps_init的参数为machine_desc结构体.以s3c6410为例,在arch/arm/mach-s3c64xx/mach-smdk6410.c中使用上述宏声明machine_ ...