前言
本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理。
PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取
python免费学习资料以及群交流解答点击即可加入
导读
在进行数据分析时,一般要先对数据进行描述性统计分析,以发现其内在的规律,再选择进一步分析的方法。描述性统计分析要对调查总体所有变量的有关数据做统计性描述,主要包括数据的频数分析、数据的集中趋势分析、数据离散程度分析、数据的分布以及一些基本的统计图形。
本文以数据集classdata为案例来说明如何计算数据探索过程中的各种数据指标,此数据集为某个班级的学生信息数据,包含姓名、性别、身高和体重,首先我们创建数据帧,代码如下:
import pandas as pd
import numpy as np
classdata=pd.read_csv("D:/Pythondata/data/class.csv")
classdata.head()
运行上述程序,结果如图1所示,展示了数据集classdata的前5个观测样本。
一、集中趋势
1.算术平均值
Pandas中计算变量均值的方法主要有2种,一是直接使用describle函数,一个是调用mean函数,代码如下所示:
classdata.mean()
运行程序,结果如下所示,可知年龄Age的均值为13.3,身高62.34,体重100。
Age 13.315789
Height 62.336842
Weight 100.026316
dtype: float64
同样,我们调用describe,代码如下所示:
classdata.describe()
运行程序,结果如下图2所示,与调用mean函数的计算结果一致。
2.几何平均数
计算变量的几何平均值,需要调用Python库scipy,比如我们计算数据集classdata的变量Heigth的几何平均值,代码如下所示:
from scipy import stats
stats.gmean(classdata['Height'])
运行程序,结果如下所示:
62.133135310943146
3.众数
在Pandas中,我们可以直接调用mode函数来计算变量的众数,比如,我们计算变量Age的众数,代码如下所示:
classdata['Age'].mode()
运行程序后,结果如下所示
12
二、离散程度
1.极差与四分位差
极差也叫全距,是一组数据的最大值与最小值之差;四分位差是指第三分位数与第一分位数之差,也称为内距或四分间距。利用describe函数计算最大值、最小值以及分位数,即可计算极差和四分位差.
stat = classdata.describe() #保存基本统计量
stat.loc['range'] = stat.loc['max']-stat.loc['min'] #极差
stat.loc['dis'] = stat.loc['75%']-stat.loc['25%'] #四分位数间距
print(stat)
运行上述程序,结果如下图3所示,变量Age的极差为5,四分位差为2.5,变量Heigth的极差为20.7,四分位差为7.65,变量Weight的极差为99.5,四分位差为28。
2.平均离差
平均离差是各变量值与其平均数之差的绝对值之和的平均数。Pandas中计算平均差的为mad函数,直接调用即可,比如我们计算各个变量的平均差,则代码如下所示:
classdata.mad()
运行程序后,其结果如下所示:
Age 1.279778
Height 4.069252
Weight 17.343490
dtype: float64
3.标准差
Pandas中计算标准差的方式有多种,其中函数describe和std均可计算,我们在前文中已经展示了describe函数的用法,在此不再累述,我们直接调用std函数即可,代码如下:
classdata.std()
运行上述程序,结果如下所示:
Age 1.492672
Height 5.127075
Weight 22.773933
dtype: float64
4.离散系数
离散系数通常是就标准差来计算的,因此,也称为标准差系数,它是一组数据的标准差与其对应的平均数之比,是衡量数据离散程度的相对指标。
我们可以通过如下程序计算标准差系数,代码如下:
stat2 = classdata.describe()
stat2.loc['var'] = stat2.loc['std']/stat2.loc['mean']
stat2
运行上述程序,结果如下图4所示:
三、分布状态
1.偏态
偏态是对分布偏斜方向和程度的测度,Pandas中可以直接调用skew函数计算变量的偏态系数,代码如下所示:
classdata.skew()
运行上述程序,结果如下所示,其中变量Age、Height和Weight的偏态系数分别为0.06、-0.26和0.18。
Age 0.063612
Height -0.259670
Weight 0.183351
dtype: float64
2.峰度
峰度是分布集中趋势高峰的形状,Pandas中可以直接调用kurt函数计算变量的偏态系数,代码如下所示:
classdata.kurt()
运行上述程序,结果如下所示,其中变量Age、Height和Weight的偏态系数分别为-1.11、-0.14和0.68。
Age -1.110926
Height -0.138969
Weight 0.683365
dtype: float64
四、相关分析
1.散点图
制散点图的方法很多,可以直接调用Pandas库的plot.scatter函数进行绘制,比如如下绘制散点图的程序。
classdata.plot.scatter(x='Age', y='Height')
运行上述程序,结果如图5所示,从散点图的数据分布可以看出,变量Height和Age呈现很强的相关关系。
同样,我们也可以调用matplotlib库的pyplot函数进行散点图的绘制,代码如下所示:
import matplotlib.pyplot as plt
plt.scatter(classdata['Height'],classdata['Weight'] )
plt.xlabel("Height")
plt.ylabel("Weight")
plt.show()
运行上述程序,结果如下图6所示,从散点图的数据分布可以看出,变量Height和Weight同样呈现很强的相关关系。
2.相关系数
在Pandas中可以直接调用corr函数来计算变量之间的相关系数,如下程序:
classdata.corr()
运行程序后,结果如图7所示:
除了计算相关系数矩阵之外,我们还可以绘制相关系数矩阵图,此处需调用seaborn库进行绘制,代码如下所示:
import seaborn as sns
%matplotlib inline
# calculate the correlation matrix
corr = classdata.corr()
# plot the heatmap
sns.heatmap(corr,xticklabels=corr.columns,yticklabels=corr.columns)
运行上述程序之后,结果如图8所示: