zoukankan      html  css  js  c++  java
  • python数据分析工具——Pandas、StatsModels、Scikit-Learn

    Pandas

    Pandas是 Python下最强大的数据分析和探索工具。它包含高级的数据结构和精巧的工具,使得在 Python中处理数据非常快速和简单。 Pandas构建在 Numpy之上,它使得以 Numpy为中心的应用很容易使用。Pandas的功能非常强大,支持类似于SQL的数据增、删、查、改,并且带有丰富的数据处理函数;支持时间序列分析功能;支持灵活处理缺失数据等。

    Pandas的安装相对来说比较容易,安装好 Numpy之后,就可以直接安装了,通过pip install pandas或下载源码后 python setup. py install安装均可。由于我们频繁用到读取和写入Excel,但默认的 Pandas还不能读写 Excel文件,需要安装xlrd(读)和xlwt(写)库才能支持 Excel的读写,方法如下:

    pip install xrd #为 Python添加读取 Excel的功能

    pip install xlwt #为 Python添加写入 Excel的功能

    Pandas基本的数据结构是 Series和 Dataframe。顾名思义, Series就是序列,类似一维数组; Data Frame则是相当于一张二维的表格,类似二维数组,它的每一列都是一个 Series。为了定位 Series中的元素, Pandas提供了Index对象,每个 Series都会带有一个对应的Index,用来标记不同的元素, Index的内容不一定是数字,也可以是字母、中文等,它类似于SQL中的主键。

    类似地, Data Frame相当于多个带有同样 Index的 Series的组合,每个 Seiries都带有唯一的表头,用来标识不同的 Series。举个例子:

    # -*- coding:utf-8 -*-

    import pandas as pd #通常用pd作为 pandas的别名。

    s=pd.Series([1,2,3], index=['a','b','c']) #创建一个序列s

    d=pd.DataFrame([[1,2,3],[4,5,6]], columns=['a','b','c']) #创建一个表

    d2=pd.DataFrame(s) #也可以用已有的序列来创建表格

    print(d.head()) #预览前5行数据

    print(d.describe()) #数据基本统计量

    pd.read_excel('data.xls') #读取Exce1文件,创建 Dataframe

    pd.read_csv('data.csv', encoding='utf-8') #读取文本格式的数据,一般用 encoding指定编码。

    StatsModels

    Pandas着眼于数据的读取、处理和探索,而StatsModels则更加注重数据的统计建模分析,它使得 Python有了R语言的味道。 StatsModels支持与 Pandas进行数据交互,因此,它与 Pandas结合,成为了 Python下强大的数据挖掘组合。

    安装StatsModels相当简单,既可以通过pip安装,又可以通过源码安装。对于Windows用户来说,官网上甚至已经有编译好的exe文件以供下载。如果手动安装的话,需要自行解决好依赖问题, Statmodel依赖于Pandas(当然也依赖于 Pandas所依赖的),同时还依赖于pasty(一个描述统计的库)。

    下面是一个用 Stats Models来进行ADF平稳性检验的例子。

    # -*- coding: utf-8 -*-

    from statsmodels.tsa.stattools import adfuller as ADF #导入ADF恰验

    import numpy as np

    ADF.(np.random.rand(100)) #返回的结果有ADF、p值

    Scikit-Learn

    Scikit-Learn是 Python下强大的机器学习工具包,它提供了完善的机器学习工具箱,包括数据预处理、分类、回归、聚类、预测和模型分析等。Scikit-Learn依赖于 Numpy、 Scipy和 Matplotlib,因此,只需要提前安装好这几个库,然后安装 Scikit-Learn就基本上没有什么问题了,安装方法和之前一样,要不就是pipinstall scikit-leam安装,要不就是下载源码自己安装。

    创建一个机器学习的模型很简单:

    # -*- coding:utf-8 -*-

    from sklearn.linear_model import Linearregression #导入线性回归模型

    model= Linearregression() #建立线性回归模型

    print (model)

    1)所有模型提供的接口有:

    model fit0:训练模型,对于监督模型来说是 fit(x,y),对于非监督模型是fit(X)。

    2)监督模型提供的接口有:

    model predict(xnew):预测新样本

    model predict proba(Xnew):预测概率,仅对某些模型有用(比如LR)

    model score:得分越高,fit越好

    3)非监督模型提供的接口有:

    model transform(:从数据中学到新的“基空间”

    model fit transform:从数据中学到新的基并将这个数据按照这组“基”进行转换。

    Scikit- Learn本身提供了一些实例数据,比较常见的有安德森鸢尾花卉数据集、手写图像数据集等。现在使用鸢尾花数据集iris写一个简单的机器学习的例子。对于这个数据集,可以阅读《R语言数据挖掘实践——数据挖掘简介

    # -*- coding:utf-8 -*-

    from sklearn import datasets #导入数据集

    iris= datasets.load_iris() #加载数据集

    print(iris.data.shape) #查看数据集大小

    from sklearn import svm #导入SVM模型

    clf=svm. LinearSVC() #建立线性SVM分类器

    clf.fit(iris.data,iris.target) #用数据训练模型

    clf.predict([[5.0,3.6,1.3,0.25]]) #训练好模型之后,输入新的数据进行预测

    clf.coef_ #查看训练好模型的参数

  • 相关阅读:
    生活中头疼脑热及医生诊断用药相关,持续更新
    python3 面试题 英文单词全部都是以首字母大写,逐个反转每个单词
    python 代码如何打包成.exe文件(Pyinstaller)
    charles使用
    经典bug
    python3面试-查找字符串数组中的最长公共前缀
    python3面试题 按规律写出下一个数1,11,21,1211,111221
    python3 测试的时候如何批量随机生成伪数据?(faker模块的)
    python3面试题-一个包含n个整数的数组a,判断a中是否存在三个元素,a,b,c,使得a+b+c=0
    python3面试-将N(N<10000)个人排成一排,从第1个人开始报数;如果报数是M的倍数就出列
  • 原文地址:https://www.cnblogs.com/cuiyubo/p/8916847.html
Copyright © 2011-2022 走看看