最近得到了一些四级成绩数据,大概500多个,因而突发奇想是否可以看看这些成绩数据是否知足所谓的正态分布呢?说干就干,因而有了这篇文章。
文章顺带介绍了xlrd模块的一些用法和matplotlib画自定义数据的条形图和随机的条形图的一些方法,而且提供了一些相关连接,可做为学习matplotlib和numpy的资源,但愿对读者也有帮助。html
更优美的格式见这里python
1 |
import xlrd |
1 |
data = xlrd.open_workbook('excelFile.xls') |
获取一个工做表数组
1 |
table = data.sheets()[0] #经过索引顺序获取 |
获取整行和整列的值(数组)dom
1 |
table.row_values(i) |
循环行列表数据svn
1 |
for i in range(nrows ): |
单元格函数
1 |
cell_A1 = table.cell(0,0).value |
使用行列索引工具
1 |
cell_A1 = table.row(0)[0].value |
简单的写入学习
1 |
row = 0 |
1 |
import xlrd |
import xlrd import numpy as np from math import * import pylab as pl import matplotlib.pyplot as plt data = xlrd.open_workbook('D:\\Python Workspace\\Data\\cet4.xls') table = data.sheets()[0] #sheet 0 col5 = table.col_values(5)[1:] ha = [int(i) for i in col5] #成绩数据 mu = np.mean(ha) #平均值 sigma = np.std(ha) #标准差 data = np.random.normal(mu,sigma,1000) #生成正态分布随机数据 x = np.linspace(0,700,1000) y = (1. / sqrt(2 * np.pi) / sigma)*np.exp( -((x-mu)**2/(2*sigma**2)) ) plt.hist(data,bins=100,facecolor='g',alpha=0.44) plt.hist(ha,bins=70,facecolor='r',histtype='stepfilled') plt.plot(x,y,color='b') #正态分布曲线 plt.xlabel('Score') plt.ylabel('Number of people') plt.title('Distribution of CET-4 Scores') plt.show()
图2
且可求得数据的均值和标准差分别为:476.743785851和104.816562585
由图可见,绿色条形图是$\mu$=476.743785851,$\sigma$=104.816562585的正态分布条形图,而红色是四级成绩数据的分布图,虽然因为数据较少(500多个数据),因此拟合较差,可是能够看出成绩数据仍是基本知足正态分布的。
不知道为啥,正态曲线没有画出来,单独画正态曲线是能够画出来的,有待研究。.net
绘图均可以调用matplotlib.pyplot库来进行,其中的hist函数能够直接绘制直方图。
调用方式:
1 |
n, bins, patches = plt.hist(arr, bins=10, normed=0, facecolor='black', edgecolor='black',alpha=1,histtype='bar') |
hist的参数很是多,但经常使用的就这六个,只有第一个是必须的,后面四个可选
arr: 须要计算直方图的一维数组
bins: 直方图的柱数,可选项,默认为10
normed: 是否将获得的直方图向量归一化。默认为0
facecolor: 直方图颜色
edgecolor: 直方图边框颜色
alpha: 透明度
histtype: 直方图类型,‘bar’, ‘barstacked’, ‘step’, ‘stepfilled’
返回值 :
n: 直方图向量,是否归一化由参数normed设定
bins: 返回各个bin的区间范围
patches: 返回每一个bin里面包含的数据,是一个list
摘自这里 from denny
库的主页
gallary
matplotlib的一些示例及其代码,是很好的学习工具。
用python作科学计算
用Python做科学计算的一些工具
xlrd文档
numpy的一些方法