1 概述
数据可视化,从数据层面,包括以下两块内容:
a单变量的可视化:主要研究变量的自身特性
b多变量的联合可视化:主要研究变量与变量之间的相关性
其中,单变量的可视化,要根据数据的类型来分别处理:
分类变量(categorical variable)
常用的有:饼图、柱形图
数值变量(numerical variable)
常用的有:概率密度图、直方图、箱式图
2 导入数据
%matplotlib inline import matplotlib.pyplot as plt import pandas as pd import numpy as np import seaborn as sns df = pd.read_csv('forestfires.csv') df.head() # 看前5行
data:image/s3,"s3://crabby-images/f7dbf/f7dbf71c009d9c8df8fce3736b015260cc76101d" alt="python可视化"
3 分类特征
分类特征主要看两个方面:
a有几种分类
b每种分类的数量(或者比例)
这里为了演示,用day变量,代表了星期。
order = ['mon', 'tue', 'wed', 'thu', 'fri', 'sat', 'sun'] day_count = df['day'].value_counts() day_count = day_count[order] # 不用loc的话就默认从大到小排序 day_count
结果为,可以看到,数据集里这个变量的分布还算平均。
mon 74 tue 64 wed 54 thu 61 fri 85 sat 84 sun 95 Name: day, dtype: int64
3.1 饼图
注意分类的种类不能太多,不然饼图就会被切得很细。
a pandas.Series.plot.pie
用autopct设置数字的格式。
day_count.plot.pie(autopct='%.2f%%')
data:image/s3,"s3://crabby-images/1f242/1f242b445a640ff7f73aaf542359a614cb9eb8f6" alt="python可视化"
b matplotlib.pyplot.pie
plt.pie(day_count, autopct='%.2f%%', labels=day_count.index)
data:image/s3,"s3://crabby-images/bc374/bc3742aff51571d58aa209cde392487c07ffdb8e" alt="python可视化"
3.2 柱状图
a pandas.Series.plot.pie
day_count.plot.bar()
data:image/s3,"s3://crabby-images/48094/480947358d72a844e3c53892d32116d8dd0af717" alt="python可视化"
b matplotlib.pyplot.bar
pos = range(len(day_count)) plt.bar(pos, day_count.values) plt.xticks(pos, day_count.index)
data:image/s3,"s3://crabby-images/f9f5a/f9f5adbc5d1caf3945b4a059f06b719542ddd1a8" alt="python可视化"
c seaborn.barplot
sns.barplot(day_count.index, day_count.values)
data:image/s3,"s3://crabby-images/cd7a9/cd7a9bc3f9b006aa7371cfa087baad339271f254" alt="python可视化"
d seaborn.countplot
sns.countplot(df['day'])
data:image/s3,"s3://crabby-images/21c99/21c9979f4f54c8637a3375cd1b6c8843bf167254" alt="python可视化"
用这个的好处在于,自动计算取值及其数量并可视化,节省一个步骤。函数中,可以设置order=order来指定顺序。
4 数值特征
数值特征主要看两个方面:它的取值区间,不同子区间的数量分布(或者密度分布)。
为了演示,用temp变量,代表温度。
temperature = df['temp']
4.1 直方图
a pandas.Series.plot.hist
temperature.plot.hist()
data:image/s3,"s3://crabby-images/8728d/8728d59a2d383359282ddd5fd1ca2d0c1d669db8" alt="python可视化"
b matplotlib.pyplot.hist
plt.hist(temperature)
data:image/s3,"s3://crabby-images/ba0ff/ba0ff44ee9a3cdca5e7990a6234b4c8352aa7ac2" alt="python可视化"
c seaborn.rugplot
plt.hist(temperature, color='orange') sns.rugplot(temperature)
data:image/s3,"s3://crabby-images/2a6aa/2a6aaa08893e409ae85baa591135880efb8a30f6" alt="python可视化"
4.2 概率密度图
a pandas.Series.plot.density
temperature.plot.density()
data:image/s3,"s3://crabby-images/cb41d/cb41d2950bbc093e9dc9a556cd0d5541be5e7ae6" alt="python可视化"
b seaborn.kdeplot
sns.kdeplot(temperature)
data:image/s3,"s3://crabby-images/cd7ad/cd7ad1280b622dffb97a41bc7a8324446a0eb4b3" alt="python可视化"
c seaborn.distplot
sns.distplot(temperature)
data:image/s3,"s3://crabby-images/09e05/09e056dfc549d219061060f96e1223c10139b378" alt="python可视化"
4.3 箱式图
a pandas.Series.plot.box
temperature.plot.box()
data:image/s3,"s3://crabby-images/afc5a/afc5a8e8a2c4b25b07cfe2445efa03520bb424d5" alt="python可视化"
b matplotlib.pyplot.boxplot
plt.boxplot(temperature) plt.show()
data:image/s3,"s3://crabby-images/14f86/14f86817934d13fdb909a39eb3da5f2e665c809e" alt="python可视化"
c seaborn.boxplot
orient默认值是h(水平),也可以设为v(垂直)。
sns.boxplot(temperature, orient='v')
data:image/s3,"s3://crabby-images/3c0a6/3c0a6c3c32d6955733afc85093383de59b09b956" alt="python可视化"