最具影响力的数字化技术在线社区

168主编 发表于 2019-1-16 18:26:57

Matplotlib 可视化最有价值的 50 个图表(附完整 Python 源代码)

翻译 | Lemon个人公众号:Python数据之道个人博客:liyangbit.com来源 | Machine Learning Plus原文:https://www.machinelearningplus.com/plots/top-50-matplotlib-visualizations-the-master-plots-python/本文总结了 Matplotlib 以及 Seaborn 用的最多的50个图形,掌握这些图形的绘制,对于数据分析的可视化有莫大的作用,强烈推荐大家阅读后续内容。如果觉得内容不错,欢迎分享到您的朋友圈。Tips:(1)本文原文部分代码有不准确的地方,已进行修改;(2)所有正确的源代码,我已整合到 jupyter notebook 文件中,源代码:https://github.com/liyangbit/PyDataRoad/tree/master/projects/matplotlib-top-50-visualizations(3)运行本文代码,除了安装 matplotlib 和 seaborn 可视化库外,还需要安装其他的一些辅助可视化库,已在代码部分作标注,具体内容请查看下面文章内容。(4)由于微信文章总字数不能超过5万字阅读原文;在数据分析和可视化中最有用的 50 个 Matplotlib 图表。 这些图表列表允许您使用 python 的 matplotlib 和 seaborn 库选择要显示的可视化对象。介绍这些图表根据可视化目标的7个不同情景进行分组。 例如,如果要想象两个变量之间的关系,请查看“关联”部分下的图表。 或者,如果您想要显示值如何随时间变化,请查看“变化”部分,依此类推。有效图表的重要特征:
[*]在不歪曲事实的情况下传达正确和必要的信息。
[*]设计简单,您不必太费力就能理解它。
[*]从审美角度支持信息而不是掩盖信息。
[*]信息没有超负荷。
准备工作在代码运行前先引入下面的设置内容。 当然,单独的图表,可以重新设置显示要素。
[*]# !pip install brewer2mpl
[*]import numpy as np
[*]import pandas as pd
[*]import matplotlib as mpl
[*]import matplotlib.pyplot as plt
[*]import seaborn as sns
[*]import warnings; warnings.filterwarnings(action='once')
[*]
[*]large = 22; med = 16; small = 12
[*]params = {'axes.titlesize': large,
[*]'legend.fontsize': med,
[*]'figure.figsize': (16, 10),
[*]'axes.labelsize': med,
[*]'axes.titlesize': med,
[*]'xtick.labelsize': med,
[*]'ytick.labelsize': med,
[*]'figure.titlesize': large}
[*]plt.rcParams.update(params)
[*]plt.style.use('seaborn-whitegrid')
[*]sns.set_style("white")
[*]%matplotlib inline
[*]
[*]# Version
[*]print(mpl.__version__) #> 3.0.0
[*]print(sns.__version__) #> 0.9.0

[*]3.0.2
[*]0.9.0
一、关联 (Correlation)关联图表用于可视化2个或更多变量之间的关系。 也就是说,一个变量如何相对于另一个变化。1 散点图(Scatter plot)散点图是用于研究两个变量之间关系的经典的和基本的图表。 如果数据中有多个组,则可能需要以不同颜色可视化每个组。 在 matplotlib 中,您可以使用 plt.scatterplot()方便地执行此操作。
[*]# Import dataset
[*]midwest = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/midwest_filter.csv")
[*]
[*]# Prepare Data
[*]# Create as many colors as there are unique midwest['category']
[*]categories = np.unique(midwest['category'])
[*]colors =
[*]
[*]# Draw Plot for Each Category
[*]plt.figure(figsize=(16, 10), dpi= 80, facecolor='w', edgecolor='k')
[*]
[*]for i, category in enumerate(categories):
[*]plt.scatter('area', 'poptotal',
[*]data=midwest.loc,
[*]s=20, cmap=colors, label=str(category))
[*]# "c=" 修改为 "cmap=",Python数据之道 备注
[*]
[*]# Decorations
[*]plt.gca().set(xlim=(0.0, 0.1), ylim=(0, 90000),
[*]xlabel='Area', ylabel='Population')
[*]
[*]plt.xticks(fontsize=12); plt.yticks(fontsize=12)
[*]plt.title("Scatterplot of Midwest Area vs Population", fontsize=22)
[*]plt.legend(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/3dbee6b895284be8a1ddb893e8af805c.jpeg图12 带边界的气泡图(Bubble plot with Encircling)有时,您希望在边界内显示一组点以强调其重要性。 在这个例子中,你从数据框中获取记录,并用下面代码中描述的 encircle()来使边界显示出来。
[*]from matplotlib import patches
[*]from scipy.spatial import ConvexHull
[*]import warnings; warnings.simplefilter('ignore')
[*]sns.set_style("white")
[*]
[*]# Step 1: Prepare Data
[*]midwest = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/midwest_filter.csv")
[*]
[*]# As many colors as there are unique midwest['category']
[*]categories = np.unique(midwest['category'])
[*]colors =
[*]
[*]# Step 2: Draw Scatterplot with unique color for each category
[*]fig = plt.figure(figsize=(16, 10), dpi= 80, facecolor='w', edgecolor='k')
[*]
[*]for i, category in enumerate(categories):
[*]plt.scatter('area', 'poptotal', data=midwest.loc,
[*]s='dot_size', cmap=colors, label=str(category), edgecolors='black', linewidths=.5)
[*]# "c=" 修改为 "cmap=",Python数据之道 备注
[*]
[*]# Step 3: Encircling
[*]# https://stackoverflow.com/questions/44575681/how-do-i-encircle-different-data-sets-in-scatter-plot
[*]def encircle(x,y, ax=None, **kw):
[*]if not ax: ax=plt.gca()
[*]p = np.c_
[*]hull = ConvexHull(p)
[*]poly = plt.Polygon(p, **kw)
[*]ax.add_patch(poly)
[*]
[*]# Select data to be encircled
[*]midwest_encircle_data = midwest.loc
[*]
[*]# Draw polygon surrounding vertices
[*]encircle(midwest_encircle_data.area, midwest_encircle_data.poptotal, ec="k", fc="gold", alpha=0.1)
[*]encircle(midwest_encircle_data.area, midwest_encircle_data.poptotal, ec="firebrick", fc="none", linewidth=1.5)
[*]
[*]# Step 4: Decorations
[*]plt.gca().set(xlim=(0.0, 0.1), ylim=(0, 90000),
[*]xlabel='Area', ylabel='Population')
[*]
[*]plt.xticks(fontsize=12); plt.yticks(fontsize=12)
[*]plt.title("Bubble Plot with Encircling", fontsize=22)
[*]plt.legend(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/fb0abcb0e7f2497b8a35be0f6d20f412.jpeg图23 带线性回归最佳拟合线的散点图 (Scatter plot with linear regression line of best fit)如果你想了解两个变量如何相互改变,那么最佳拟合线就是常用的方法。 下图显示了数据中各组之间最佳拟合线的差异。 要禁用分组并仅为整个数据集绘制一条最佳拟合线,请从下面的 sns.lmplot()调用中删除 hue ='cyl'参数。
[*]# Import Data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/mpg_ggplot2.csv")
[*]df_select = df.loc), :]
[*]
[*]# Plot
[*]sns.set_style("white")
[*]gridobj = sns.lmplot(x="displ", y="hwy", hue="cyl", data=df_select,
[*]height=7, aspect=1.6, robust=True, palette='tab10',
[*]scatter_kws=dict(s=60, linewidths=.7, edgecolors='black'))
[*]
[*]# Decorations
[*]gridobj.set(xlim=(0.5, 7.5), ylim=(0, 50))
[*]plt.title("Scatterplot with line of best fit grouped by number of cylinders", fontsize=20)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/f61d6224e0704b11b6229593ff5f156c.jpeg图3针对每列绘制线性回归线或者,可以在其每列中显示每个组的最佳拟合线。 可以通过在 sns.lmplot()中设置 col=groupingcolumn参数来实现,如下:
[*]# Import Data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/mpg_ggplot2.csv")
[*]df_select = df.loc), :]
[*]
[*]# Each line in its own column
[*]sns.set_style("white")
[*]gridobj = sns.lmplot(x="displ", y="hwy",
[*]data=df_select,
[*]height=7,
[*]robust=True,
[*]palette='Set1',
[*]col="cyl",
[*]scatter_kws=dict(s=60, linewidths=.7, edgecolors='black'))
[*]
[*]# Decorations
[*]gridobj.set(xlim=(0.5, 7.5), ylim=(0, 50))
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/7c343c6af0fa410fa6e4a4f0e24ede15.jpeg图3-24 抖动图 (Jittering with stripplot)通常,多个数据点具有完全相同的 X 和 Y 值。 结果,多个点绘制会重叠并隐藏。 为避免这种情况,请将数据点稍微抖动,以便您可以直观地看到它们。 使用 seaborn 的 stripplot()很方便实现这个功能。
[*]# Import Data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/mpg_ggplot2.csv")
[*]
[*]# Draw Stripplot
[*]fig, ax = plt.subplots(figsize=(16,10), dpi= 80)
[*]sns.stripplot(df.cty, df.hwy, jitter=0.25, size=8, ax=ax, linewidth=.5)
[*]
[*]# Decorations
[*]plt.title('Use jittered plots to avoid overlapping of points', fontsize=22)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/df836d04acc944dabcd010dbeb253a3b.jpeg图45 计数图 (Counts Plot)避免点重叠问题的另一个选择是增加点的大小,这取决于该点中有多少点。 因此,点的大小越大,其周围的点的集中度越高。
[*]# Import Data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/mpg_ggplot2.csv")
[*]df_counts = df.groupby(['hwy', 'cty']).size().reset_index(name='counts')
[*]
[*]# Draw Stripplot
[*]fig, ax = plt.subplots(figsize=(16,10), dpi= 80)
[*]sns.stripplot(df_counts.cty, df_counts.hwy, size=df_counts.counts*2, ax=ax)
[*]
[*]# Decorations
[*]plt.title('Counts Plot - Size of circle is bigger as more points overlap', fontsize=22)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/a5ddf3fd38684a8d8a1c0374c53934a5.jpeg图56 边缘直方图 (Marginal Histogram)边缘直方图具有沿 X 和 Y 轴变量的直方图。 这用于可视化 X 和 Y 之间的关系以及单独的 X 和 Y 的单变量分布。 这种图经常用于探索性数据分析(EDA)。http://5b0988e595225.cdn.sohucs.com/images/20181228/5ab4d48d0c0241b68bcf0b78bbda4fe9.jpeg图67 边缘箱形图 (Marginal Boxplot)边缘箱图与边缘直方图具有相似的用途。 然而,箱线图有助于精确定位 X 和 Y 的中位数、第25和第75百分位数。http://5b0988e595225.cdn.sohucs.com/images/20181228/3bdb1b3d79644764842ca664f5ffea31.jpeg图78 相关图 (Correllogram)相关图用于直观地查看给定数据框(或二维数组)中所有可能的数值变量对之间的相关度量。
[*]# Import Dataset
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mtcars.csv")
[*]
[*]# Plot
[*]plt.figure(figsize=(12,10), dpi= 80)
[*]sns.heatmap(df.corr(), xticklabels=df.corr().columns, yticklabels=df.corr().columns, cmap='RdYlGn', center=0, annot=True)
[*]
[*]# Decorations
[*]plt.title('Correlogram of mtcars', fontsize=22)
[*]plt.xticks(fontsize=12)
[*]plt.yticks(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/6995976bdceb4a6a894fbdb813aca932.jpeg图89 矩阵图 (Pairwise Plot)矩阵图是探索性分析中的最爱,用于理解所有可能的数值变量对之间的关系。 它是双变量分析的必备工具。
[*]# Load Dataset
[*]df = sns.load_dataset('iris')
[*]
[*]# Plot
[*]plt.figure(figsize=(10,8), dpi= 80)
[*]sns.pairplot(df, kind="scatter", hue="species", plot_kws=dict(s=80, edgecolor="white", linewidth=2.5))
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/6aff9a628519426da390ca19769c0255.jpeg图9
[*]# Load Dataset
[*]df = sns.load_dataset('iris')
[*]
[*]# Plot
[*]plt.figure(figsize=(10,8), dpi= 80)
[*]sns.pairplot(df, kind="reg", hue="species")
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/19ea646fa1e4407d8b45a8abf0ffe1fe.jpeg图9-2二、偏差 (Deviation) 10 发散型条形图 (Diverging Bars)如果您想根据单个指标查看项目的变化情况,并可视化此差异的顺序和数量,那么散型条形图 (Diverging Bars) 是一个很好的工具。 它有助于快速区分数据中组的性能,并且非常直观,并且可以立即传达这一点。
[*]# Prepare Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mtcars.csv")
[*]x = df.loc[:, ['mpg']]
[*]df['mpg_z'] = (x - x.mean())/x.std()
[*]df['colors'] = ['red' if x < 0 else 'green' for x in df['mpg_z']]
[*]df.sort_values('mpg_z', inplace=True)
[*]df.reset_index(inplace=True)
[*]
[*]# Draw plot
[*]plt.figure(figsize=(14,10), dpi= 80)
[*]plt.hlines(y=df.index, xmin=0, xmax=df.mpg_z, color=df.colors, alpha=0.4, linewidth=5)
[*]
[*]# Decorations
[*]plt.gca().set(ylabel='$Model$', xlabel='$Mileage$')
[*]plt.yticks(df.index, df.cars, fontsize=12)
[*]plt.title('Diverging Bars of Car Mileage', fontdict={'size':20})
[*]plt.grid(linestyle='--', alpha=0.5)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/897cdbdf50be4c0c8bd1e7f044f5b176.jpeg图1011 发散型文本 (Diverging Texts)发散型文本 (Diverging Texts)与发散型条形图 (Diverging Bars)相似,如果你想以一种漂亮和可呈现的方式显示图表中每个项目的价值,就可以使用这种方法。
[*]# Prepare Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mtcars.csv")
[*]x = df.loc[:, ['mpg']]
[*]df['mpg_z'] = (x - x.mean())/x.std()
[*]df['colors'] = ['red' if x < 0 else 'green' for x in df['mpg_z']]
[*]df.sort_values('mpg_z', inplace=True)
[*]df.reset_index(inplace=True)
[*]
[*]# Draw plot
[*]plt.figure(figsize=(14,14), dpi= 80)
[*]plt.hlines(y=df.index, xmin=0, xmax=df.mpg_z)
[*]for x, y, tex in zip(df.mpg_z, df.index, df.mpg_z):
[*]t = plt.text(x, y, round(tex, 2), horizontalalignment='right' if x < 0 else 'left',
[*]verticalalignment='center', fontdict={'color':'red' if x < 0 else 'green', 'size':14})
[*]
[*]# Decorations
[*]plt.yticks(df.index, df.cars, fontsize=12)
[*]plt.title('Diverging Text Bars of Car Mileage', fontdict={'size':20})
[*]plt.grid(linestyle='--', alpha=0.5)
[*]plt.xlim(-2.5, 2.5)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/da0aa3e6994b494dae672dececd44cc5.jpeg图1112 发散型包点图 (Diverging Dot Plot)发散型包点图 (Diverging Dot Plot)也类似于发散型条形图 (Diverging Bars)。 然而,与发散型条形图 (Diverging Bars)相比,条的缺失减少了组之间的对比度和差异。
[*]# Prepare Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mtcars.csv")
[*]x = df.loc[:, ['mpg']]
[*]df['mpg_z'] = (x - x.mean())/x.std()
[*]df['colors'] = ['red' if x < 0 else 'darkgreen' for x in df['mpg_z']]
[*]df.sort_values('mpg_z', inplace=True)
[*]df.reset_index(inplace=True)
[*]
[*]# Draw plot
[*]plt.figure(figsize=(14,16), dpi= 80)
[*]plt.scatter(df.mpg_z, df.index, s=450, alpha=.6, color=df.colors)
[*]for x, y, tex in zip(df.mpg_z, df.index, df.mpg_z):
[*]t = plt.text(x, y, round(tex, 1), horizontalalignment='center',
[*]verticalalignment='center', fontdict={'color':'white'})
[*]
[*]# Decorations
[*]# Lighten borders
[*]plt.gca().spines["top"].set_alpha(.3)
[*]plt.gca().spines["bottom"].set_alpha(.3)
[*]plt.gca().spines["right"].set_alpha(.3)
[*]plt.gca().spines["left"].set_alpha(.3)
[*]
[*]plt.yticks(df.index, df.cars)
[*]plt.title('Diverging Dotplot of Car Mileage', fontdict={'size':20})
[*]plt.xlabel('$Mileage$')
[*]plt.grid(linestyle='--', alpha=0.5)
[*]plt.xlim(-2.5, 2.5)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/8a373425ea704429aca85c8ea4f6d68a.jpeg图1213 带标记的发散型棒棒糖图 (Diverging Lollipop Chart with Markers)带标记的棒棒糖图通过强调您想要引起注意的任何重要数据点并在图表中适当地给出推理,提供了一种对差异进行可视化的灵活方式。http://5b0988e595225.cdn.sohucs.com/images/20181228/55640f4f7970414e8b063366b3e11d7c.jpeg图1314 面积图 (Area Chart)通过对轴和线之间的区域进行着色,面积图不仅强调峰和谷,而且还强调高点和低点的持续时间。 高点持续时间越长,线下面积越大。
[*]import numpy as np
[*]import pandas as pd
[*]
[*]# Prepare Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/economics.csv", parse_dates=['date']).head(100)
[*]x = np.arange(df.shape)
[*]y_returns = (df.psavert.diff().fillna(0)/df.psavert.shift(1)).fillna(0) * 100
[*]
[*]# Plot
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]plt.fill_between(x, y_returns, 0, where=y_returns >= 0, facecolor='green', interpolate=True, alpha=0.7)
[*]plt.fill_between(x, y_returns, 0, where=y_returns <= 0, facecolor='red', interpolate=True, alpha=0.7)
[*]
[*]# Annotate
[*]plt.annotate('Peak 1975', xy=(94.0, 21.0), xytext=(88.0, 28),
[*]bbox=dict(boxstyle='square', fc='firebrick'),
[*]arrowprops=dict(facecolor='steelblue', shrink=0.05), fontsize=15, color='white')
[*]
[*]
[*]# Decorations
[*]xtickvals = .upper()+"-"+str(y) for y,m in zip(df.date.dt.year, df.date.dt.month_name())]
[*]plt.gca().set_xticks(x[::6])
[*]plt.gca().set_xticklabels(xtickvals[::6], rotation=90, fontdict={'horizontalalignment': 'center', 'verticalalignment': 'center_baseline'})
[*]plt.ylim(-35,35)
[*]plt.xlim(1,100)
[*]plt.title("Month Economics Return %", fontsize=22)
[*]plt.ylabel('Monthly returns %')
[*]plt.grid(alpha=0.5)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/2c58d30cdc204a9eb14e741041ff92f8.jpeg图14三、排序 (Ranking) 15 有序条形图 (Ordered Bar Chart)有序条形图有效地传达了项目的排名顺序。 但是,在图表上方添加度量标准的值,用户可以从图表本身获取精确信息。http://5b0988e595225.cdn.sohucs.com/images/20181228/22ca324372934815a66a2eba4cfb6134.jpeg图1516 棒棒糖图 (Lollipop Chart)棒棒糖图表以一种视觉上令人愉悦的方式提供与有序条形图类似的目的。
[*]# Prepare Data
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]df = df_raw[['cty', 'manufacturer']].groupby('manufacturer').apply(lambda x: x.mean())
[*]df.sort_values('cty', inplace=True)
[*]df.reset_index(inplace=True)
[*]
[*]# Draw plot
[*]fig, ax = plt.subplots(figsize=(16,10), dpi= 80)
[*]ax.vlines(x=df.index, ymin=0, ymax=df.cty, color='firebrick', alpha=0.7, linewidth=2)
[*]ax.scatter(x=df.index, y=df.cty, s=75, color='firebrick', alpha=0.7)
[*]
[*]# Title, Label, Ticks and Ylim
[*]ax.set_title('Lollipop Chart for Highway Mileage', fontdict={'size':22})
[*]ax.set_ylabel('Miles Per Gallon')
[*]ax.set_xticks(df.index)
[*]ax.set_xticklabels(df.manufacturer.str.upper(), rotation=60, fontdict={'horizontalalignment': 'right', 'size':12})
[*]ax.set_ylim(0, 30)
[*]
[*]# Annotate
[*]for row in df.itertuples():
[*]ax.text(row.Index, row.cty+.5, s=round(row.cty, 2), horizontalalignment= 'center', verticalalignment='bottom', fontsize=14)
[*]
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/2879e34a69594daea7c4289eea99a8ec.jpeg图1617 包点图 (Dot Plot)包点图表传达了项目的排名顺序,并且由于它沿水平轴对齐,因此您可以更容易地看到点彼此之间的距离。
[*]# Prepare Data
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]df = df_raw[['cty', 'manufacturer']].groupby('manufacturer').apply(lambda x: x.mean())
[*]df.sort_values('cty', inplace=True)
[*]df.reset_index(inplace=True)
[*]
[*]# Draw plot
[*]fig, ax = plt.subplots(figsize=(16,10), dpi= 80)
[*]ax.hlines(y=df.index, xmin=11, xmax=26, color='gray', alpha=0.7, linewidth=1, linestyles='dashdot')
[*]ax.scatter(y=df.index, x=df.cty, s=75, color='firebrick', alpha=0.7)
[*]
[*]# Title, Label, Ticks and Ylim
[*]ax.set_title('Dot Plot for Highway Mileage', fontdict={'size':22})
[*]ax.set_xlabel('Miles Per Gallon')
[*]ax.set_yticks(df.index)
[*]ax.set_yticklabels(df.manufacturer.str.title(), fontdict={'horizontalalignment': 'right'})
[*]ax.set_xlim(10, 27)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/5d916b6339d44e30b6437abc30734fe3.jpeg图1718 坡度图 (Slope Chart)坡度图最适合比较给定人/项目的“前”和“后”位置。http://5b0988e595225.cdn.sohucs.com/images/20181228/b48c936790eb4ae59bf463ba5fc0257b.jpeg图1819 哑铃图 (Dumbbell Plot)哑铃图表传达了各种项目的“前”和“后”位置以及项目的等级排序。 如果您想要将特定项目/计划对不同对象的影响可视化,那么它非常有用。http://5b0988e595225.cdn.sohucs.com/images/20181228/bf1a0d17ae744f12aa97ee194b1350af.jpeg图19四、分布 (Distribution) 20 连续变量的直方图 (Histogram for Continuous Variable)直方图显示给定变量的频率分布。 下面的图表示基于类型变量对频率条进行分组,从而更好地了解连续变量和类型变量。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare data
[*]x_var = 'displ'
[*]groupby_var = 'class'
[*]df_agg = df.loc[:, ].groupby(groupby_var)
[*]vals = .values.tolist() for i, df in df_agg]
[*]
[*]# Draw
[*]plt.figure(figsize=(16,9), dpi= 80)
[*]colors =
[*]n, bins, patches = plt.hist(vals, 30, stacked=True, density=False, color=colors[:len(vals)])
[*]
[*]# Decoration
[*]plt.legend({group:col for group, col in zip(np.unique(df).tolist(), colors[:len(vals)])})
[*]plt.title(f"Stacked Histogram of ${x_var}$ colored by ${groupby_var}$", fontsize=22)
[*]plt.xlabel(x_var)
[*]plt.ylabel("Frequency")
[*]plt.ylim(0, 25)
[*]plt.xticks(ticks=bins[::3], labels=])
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/fdeaf229bc6c4b728ae20ce25608a2f1.png图2021 类型变量的直方图 (Histogram for Categorical Variable)类型变量的直方图显示该变量的频率分布。 通过对条形图进行着色,可以将分布与表示颜色的另一个类型变量相关联。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare data
[*]x_var = 'manufacturer'
[*]groupby_var = 'class'
[*]df_agg = df.loc[:, ].groupby(groupby_var)
[*]vals = .values.tolist() for i, df in df_agg]
[*]
[*]# Draw
[*]plt.figure(figsize=(16,9), dpi= 80)
[*]colors =
[*]n, bins, patches = plt.hist(vals, df.unique().__len__(), stacked=True, density=False, color=colors[:len(vals)])
[*]
[*]# Decoration
[*]plt.legend({group:col for group, col in zip(np.unique(df).tolist(), colors[:len(vals)])})
[*]plt.title(f"Stacked Histogram of ${x_var}$ colored by ${groupby_var}$", fontsize=22)
[*]plt.xlabel(x_var)
[*]plt.ylabel("Frequency")
[*]plt.ylim(0, 40)
[*]plt.xticks(ticks=bins, labels=np.unique(df).tolist(), rotation=90, horizontalalignment='left')
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/91b13d9e9ab6444b8ffa9e9acf500682.jpeg图2122 密度图 (Density Plot)密度图是一种常用工具,用于可视化连续变量的分布。 通过“响应”变量对它们进行分组,您可以检查 X 和 Y 之间的关系。以下情况用于表示目的,以描述城市里程的分布如何随着汽缸数的变化而变化。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]sns.kdeplot(df.loc == 4, "cty"], shade=True, color="g", label="Cyl=4", alpha=.7)
[*]sns.kdeplot(df.loc == 5, "cty"], shade=True, color="deeppink", label="Cyl=5", alpha=.7)
[*]sns.kdeplot(df.loc == 6, "cty"], shade=True, color="dodgerblue", label="Cyl=6", alpha=.7)
[*]sns.kdeplot(df.loc == 8, "cty"], shade=True, color="orange", label="Cyl=8", alpha=.7)
[*]
[*]# Decoration
[*]plt.title('Density Plot of City Mileage by n_Cylinders', fontsize=22)
[*]plt.legend()
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/62bc549085494c938623823e2f63f392.jpeg图2223 直方密度线图 (Density Curves with Histogram)带有直方图的密度曲线汇集了两个图所传达的集体信息,因此您可以将它们放在一个图中而不是两个图中。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(13,10), dpi= 80)
[*]sns.distplot(df.loc == 'compact', "cty"], color="dodgerblue", label="Compact", hist_kws={'alpha':.7}, kde_kws={'linewidth':3})
[*]sns.distplot(df.loc == 'suv', "cty"], color="orange", label="SUV", hist_kws={'alpha':.7}, kde_kws={'linewidth':3})
[*]sns.distplot(df.loc == 'minivan', "cty"], color="g", label="minivan", hist_kws={'alpha':.7}, kde_kws={'linewidth':3})
[*]plt.ylim(0, 0.35)
[*]
[*]# Decoration
[*]plt.title('Density Plot of City Mileage by Vehicle Type', fontsize=22)
[*]plt.legend()
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/a6812e2d034e486a89ca14acd66de2b8.jpeg图2324 Joy PlotJoy Plot允许不同组的密度曲线重叠,这是一种可视化大量分组数据的彼此关系分布的好方法。 它看起来很悦目,并清楚地传达了正确的信息。 它可以使用基于 matplotlib 的 joypy 包轻松构建。 (『Python数据之道』注:需要安装 joypy 库)
[*]# !pip install joypy
[*]# Python数据之道 备注
[*]import joypy
[*]
[*]# Import Data
[*]mpg = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]fig, axes = joypy.joyplot(mpg, column=['hwy', 'cty'], by="class", ylim='own', figsize=(14,10))
[*]
[*]# Decoration
[*]plt.title('Joy Plot of City and Highway Mileage by Class', fontsize=22)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/bdca99793c6841fd8f1ea305e849bf0e.jpeg图2425 分布式包点图 (Distributed Dot Plot)分布式包点图显示按组分割的点的单变量分布。 点数越暗,该区域的数据点集中度越高。 通过对中位数进行不同着色,组的真实定位立即变得明显。http://5b0988e595225.cdn.sohucs.com/images/20181228/793bb9dde6344b0b838d2612be673224.jpeg图2526 箱形图 (Box Plot)箱形图是一种可视化分布的好方法,记住中位数、第25个第45个四分位数和异常值。 但是,您需要注意解释可能会扭曲该组中包含的点数的框的大小。 因此,手动提供每个框中的观察数量可以帮助克服这个缺点。例如,左边的前两个框具有相同大小的框,即使它们的值分别是5和47。 因此,写入该组中的观察数量是必要的。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(13,10), dpi= 80)
[*]sns.boxplot(x='class', y='hwy', data=df, notch=False)
[*]
[*]# Add N Obs inside boxplot (optional)
[*]def add_n_obs(df,group_col,y):
[*]medians_dict = {grp:grp.median() for grp in df.groupby(group_col)}
[*]xticklabels =
[*]n_obs = df.groupby(group_col).size().values
[*]for (x, xticklabel), n_ob in zip(enumerate(xticklabels), n_obs):
[*]plt.text(x, medians_dict*1.01, "#obs : "+str(n_ob), horizontalalignment='center', fontdict={'size':14}, color='white')
[*]
[*]add_n_obs(df,group_col='class',y='hwy')
[*]
[*]# Decoration
[*]plt.title('Box Plot of Highway Mileage by Vehicle Class', fontsize=22)
[*]plt.ylim(10, 40)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/d29956396cba458a97cbb1cdedf3bd7c.jpeg图2627 包点+箱形图 (Dot + Box Plot)包点+箱形图 (Dot + Box Plot)传达类似于分组的箱形图信息。 此外,这些点可以了解每组中有多少数据点。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(13,10), dpi= 80)
[*]sns.boxplot(x='class', y='hwy', data=df, hue='cyl')
[*]sns.stripplot(x='class', y='hwy', data=df, color='black', size=3, jitter=1)
[*]
[*]for i in range(len(df['class'].unique())-1):
[*]plt.vlines(i+.5, 10, 45, linestyles='solid', colors='gray', alpha=0.2)
[*]
[*]# Decoration
[*]plt.title('Box Plot of Highway Mileage by Vehicle Class', fontsize=22)
[*]plt.legend(title='Cylinders')
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/af837b1c04384d88910cd536a228ebfc.jpeg图2728 小提琴图 (Violin Plot)小提琴图是箱形图在视觉上令人愉悦的替代品。 小提琴的形状或面积取决于它所持有的观察次数。 但是,小提琴图可能更难以阅读,并且在专业设置中不常用。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(13,10), dpi= 80)
[*]sns.violinplot(x='class', y='hwy', data=df, scale='width', inner='quartile')
[*]
[*]# Decoration
[*]plt.title('Violin Plot of Highway Mileage by Vehicle Class', fontsize=22)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/64f2dba6694944fc952158e84ecff569.jpeg图2829 人口金字塔 (Population Pyramid)人口金字塔可用于显示由数量排序的组的分布。 或者它也可以用于显示人口的逐级过滤,因为它在下面用于显示有多少人通过营销渠道的每个阶段。
[*]# Read data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/email_campaign_funnel.csv")
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(13,10), dpi= 80)
[*]group_col = 'Gender'
[*]order_of_bars = df.Stage.unique()[::-1]
[*]colors = .unique())-1)) for i in range(len(df.unique()))]
[*]
[*]for c, group in zip(colors, df.unique()):
[*]sns.barplot(x='Users', y='Stage', data=df.loc==group, :], order=order_of_bars, color=c, label=group)
[*]
[*]# Decorations
[*]plt.xlabel("$Users$")
[*]plt.ylabel("Stage of Purchase")
[*]plt.yticks(fontsize=12)
[*]plt.title("Population Pyramid of the Marketing Funnel", fontsize=22)
[*]plt.legend()
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/d528afe89b0c401bb9d9f2990dad9424.jpeg图2930 分类图 (Categorical Plots)由 seaborn库 提供的分类图可用于可视化彼此相关的2个或更多分类变量的计数分布。
[*]# Load Dataset
[*]titanic = sns.load_dataset("titanic")
[*]
[*]# Plot
[*]g = sns.catplot("alive", col="deck", col_wrap=4,
[*]data=titanic,
[*]kind="count", height=3.5, aspect=.8,
[*]palette='tab20')
[*]
[*]fig.suptitle('sf')
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/3a5249ecac1b4c0197536dc905ca1f0f.png图30
[*]# Load Dataset
[*]titanic = sns.load_dataset("titanic")
[*]
[*]# Plot
[*]sns.catplot(x="age", y="embark_town",
[*]hue="sex", col="class",
[*]data=titanic,
[*]orient="h", height=5, aspect=1, palette="tab10",
[*]kind="violin", dodge=True, cut=0, bw=.2)
http://5b0988e595225.cdn.sohucs.com/images/20181228/704ccf2cec3c4aa1b7adaf799627777d.jpeg图30-2五、组成 (Composition) 31 华夫饼图 (Waffle Chart)可以使用 pywaffle包 创建华夫饼图,并用于显示更大群体中的组的组成。(『Python数据之道』注:需要安装 pywaffle 库)
[*]#! pip install pywaffle
[*]# Reference: https://stackoverflow.com/questions/41400136/how-to-do-waffle-charts-in-python-square-piechart
[*]from pywaffle import Waffle
[*]
[*]# Import
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare Data
[*]df = df_raw.groupby('class').size().reset_index(name='counts')
[*]n_categories = df.shape
[*]colors =
[*]
[*]# Draw Plot and Decorate
[*]fig = plt.figure(
[*]FigureClass=Waffle,
[*]plots={
[*]'111': {
[*]'values': df['counts'],
[*]'labels': ["{0} ({1})".format(n, n) for n in df[['class', 'counts']].itertuples()],
[*]'legend': {'loc': 'upper left', 'bbox_to_anchor': (1.05, 1), 'fontsize': 12},
[*]'title': {'label': '# Vehicles by Class', 'loc': 'center', 'fontsize':18}
[*]},
[*]},
[*]rows=7,
[*]colors=colors,
[*]figsize=(16, 9)
[*])
http://5b0988e595225.cdn.sohucs.com/images/20181228/2ef23f2a21ba4016b37b87700392334a.png图31http://5b0988e595225.cdn.sohucs.com/images/20181228/7e8c006f1ef642d1975d4ebec0c459cb.jpeg图31-232 饼图 (Pie Chart)饼图是显示组成的经典方式。 然而,现在通常不建议使用它,因为馅饼部分的面积有时会变得误导。 因此,如果您要使用饼图,强烈建议明确记下饼图每个部分的百分比或数字。
[*]# Import
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare Data
[*]df = df_raw.groupby('class').size()
[*]
[*]# Make the plot with pandas
[*]df.plot(kind='pie', subplots=True, figsize=(8, 8))
[*]plt.title("Pie Chart of Vehicle Class - Bad")
[*]plt.ylabel("")
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/b98c53d5505c4b7eb7d73121bb5423a1.png图32http://5b0988e595225.cdn.sohucs.com/images/20181228/9aa8e3590fe046f1855934af37dfd7a7.jpeg图32-233 树形图 (Treemap)树形图类似于饼图,它可以更好地完成工作而不会误导每个组的贡献。(『Python数据之道』注:需要安装 squarify 库)
[*]# pip install squarify
[*]import squarify
[*]
[*]# Import Data
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare Data
[*]df = df_raw.groupby('class').size().reset_index(name='counts')
[*]labels = df.apply(lambda x: str(x) + " (" + str(x) + ")", axis=1)
[*]sizes = df['counts'].values.tolist()
[*]colors =
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(12,8), dpi= 80)
[*]squarify.plot(sizes=sizes, label=labels, color=colors, alpha=.8)
[*]
[*]# Decorate
[*]plt.title('Treemap of Vechile Class')
[*]plt.axis('off')
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/3f1e2a20e3914ba0b99c42e98b78651c.png图3334 条形图 (Bar Chart)条形图是基于计数或任何给定指标可视化项目的经典方式。 在下面的图表中,我为每个项目使用了不同的颜色,但您通常可能希望为所有项目选择一种颜色,除非您按组对其进行着色。 颜色名称存储在下面代码中的all_colors中。 您可以通过在 plt.plot()中设置颜色参数来更改条的颜色。
[*]import random
[*]
[*]# Import Data
[*]df_raw = pd.read_csv("https://github.com/selva86/datasets/raw/master/mpg_ggplot2.csv")
[*]
[*]# Prepare Data
[*]df = df_raw.groupby('manufacturer').size().reset_index(name='counts')
[*]n = df['manufacturer'].unique().__len__()+1
[*]all_colors = list(plt.cm.colors.cnames.keys())
[*]random.seed(100)
[*]c = random.choices(all_colors, k=n)
[*]
[*]# Plot Bars
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]plt.bar(df['manufacturer'], df['counts'], color=c, width=.5)
[*]for i, val in enumerate(df['counts'].values):
[*]plt.text(i, val, float(val), horizontalalignment='center', verticalalignment='bottom', fontdict={'fontweight':500, 'size':12})
[*]
[*]# Decoration
[*]plt.gca().set_xticklabels(df['manufacturer'], rotation=60, horizontalalignment= 'right')
[*]plt.title("Number of Vehicles by Manaufacturers", fontsize=22)
[*]plt.ylabel('# Vehicles')
[*]plt.ylim(0, 45)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/e36992e46b4b4617a9e9b679a2510449.jpeg图34六、变化 (Change) 35 时间序列图 (Time Series Plot)时间序列图用于显示给定度量随时间变化的方式。 在这里,您可以看到 1949年 至 1969年间航空客运量的变化情况。
[*]# Import Data
[*]df = pd.read_csv('https://github.com/selva86/datasets/raw/master/AirPassengers.csv')
[*]
[*]# Draw Plot
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]plt.plot('date', 'traffic', data=df, color='tab:red')
[*]
[*]# Decoration
[*]plt.ylim(50, 750)
[*]xtick_location = df.index.tolist()[::12]
[*]xtick_labels = for x in df.date.tolist()[::12]]
[*]plt.xticks(ticks=xtick_location, labels=xtick_labels, rotation=0, fontsize=12, horizontalalignment='center', alpha=.7)
[*]plt.yticks(fontsize=12, alpha=.7)
[*]plt.title("Air Passengers Traffic (1949 - 1969)", fontsize=22)
[*]plt.grid(axis='both', alpha=.3)
[*]
[*]# Remove borders
[*]plt.gca().spines["top"].set_alpha(0.0)
[*]plt.gca().spines["bottom"].set_alpha(0.3)
[*]plt.gca().spines["right"].set_alpha(0.0)
[*]plt.gca().spines["left"].set_alpha(0.3)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/661a4bb315454ef5b2f9649f4b1b5711.jpeg图3536 带波峰波谷标记的时序图 (Time Series with Peaks and Troughs Annotated)下面的时间序列绘制了所有峰值和低谷,并注释了所选特殊事件的发生。http://5b0988e595225.cdn.sohucs.com/images/20181228/79429b02975c4d29a73eb3fede8dfd60.jpeg图3637 自相关和部分自相关图 (Autocorrelation (ACF) and Partial Autocorrelation (PACF) Plot)自相关图(ACF图)显示时间序列与其自身滞后的相关性。 每条垂直线(在自相关图上)表示系列与滞后0之间的滞后之间的相关性。图中的蓝色阴影区域是显着性水平。 那些位于蓝线之上的滞后是显着的滞后。那么如何解读呢?对于空乘旅客,我们看到多达14个滞后跨越蓝线,因此非常重要。 这意味着,14年前的航空旅客交通量对今天的交通状况有影响。PACF在另一方面显示了任何给定滞后(时间序列)与当前序列的自相关,但是删除了滞后的贡献。
[*]from statsmodels.graphics.tsaplots import plot_acf, plot_pacf
[*]
[*]# Import Data
[*]df = pd.read_csv('https://github.com/selva86/datasets/raw/master/AirPassengers.csv')
[*]
[*]# Draw Plot
[*]fig, (ax1, ax2) = plt.subplots(1, 2,figsize=(16,6), dpi= 80)
[*]plot_acf(df.traffic.tolist(), ax=ax1, lags=50)
[*]plot_pacf(df.traffic.tolist(), ax=ax2, lags=20)
[*]
[*]# Decorate
[*]# lighten the borders
[*]ax1.spines["top"].set_alpha(.3); ax2.spines["top"].set_alpha(.3)
[*]ax1.spines["bottom"].set_alpha(.3); ax2.spines["bottom"].set_alpha(.3)
[*]ax1.spines["right"].set_alpha(.3); ax2.spines["right"].set_alpha(.3)
[*]ax1.spines["left"].set_alpha(.3); ax2.spines["left"].set_alpha(.3)
[*]
[*]# font size of tick labels
[*]ax1.tick_params(axis='both', labelsize=12)
[*]ax2.tick_params(axis='both', labelsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/40c9d29809204c83bb01a58027ff512b.png图3738 交叉相关图 (Cross Correlation plot)交叉相关图显示了两个时间序列相互之间的滞后。http://5b0988e595225.cdn.sohucs.com/images/20181228/7cb4a4ad4f214169bf6d04beae6746b7.png图3839 时间序列分解图 (Time Series Decomposition Plot)时间序列分解图显示时间序列分解为趋势,季节和残差分量。
[*]from statsmodels.tsa.seasonal import seasonal_decompose
[*]from dateutil.parser import parse
[*]
[*]# Import Data
[*]df = pd.read_csv('https://github.com/selva86/datasets/raw/master/AirPassengers.csv')
[*]dates = pd.DatetimeIndex(])
[*]df.set_index(dates, inplace=True)
[*]
[*]# Decompose
[*]result = seasonal_decompose(df['traffic'], model='multiplicative')
[*]
[*]# Plot
[*]plt.rcParams.update({'figure.figsize': (10,10)})
[*]result.plot().suptitle('Time Series Decomposition of Air Passengers')
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/aa7dacf0d974469ca86e8eb867f07834.jpeg图3940 多个时间序列 (Multiple Time Series)您可以绘制多个时间序列,在同一图表上测量相同的值,如下所示。http://5b0988e595225.cdn.sohucs.com/images/20181228/2e23b27b19ba4c46983a2deafd83c585.jpeg图4041 使用辅助 Y 轴来绘制不同范围的图形 (Plotting with different scales using secondary Y axis)如果要显示在同一时间点测量两个不同数量的两个时间序列,则可以在右侧的辅助Y轴上再绘制第二个系列。http://5b0988e595225.cdn.sohucs.com/images/20181228/6353920c069740e5bb32892fce798b10.jpeg图4142 带有误差带的时间序列 (Time Series with Error Bands)如果您有一个时间序列数据集,每个时间点(日期/时间戳)有多个观测值,则可以构建带有误差带的时间序列。 您可以在下面看到一些基于每天不同时间订单的示例。 另一个关于45天持续到达的订单数量的例子。在该方法中,订单数量的平均值由白线表示。 并且计算95%置信区间并围绕均值绘制。http://5b0988e595225.cdn.sohucs.com/images/20181228/d5d9ae9c02b94ab3bdd1a4383989296b.jpeg图42http://5b0988e595225.cdn.sohucs.com/images/20181228/7617058cda71415f95aae49d32830a4d.jpeg图42-243 堆积面积图 (Stacked Area Chart)堆积面积图可以直观地显示多个时间序列的贡献程度,因此很容易相互比较。http://5b0988e595225.cdn.sohucs.com/images/20181228/3c248a9c534141278fb86321f253ca25.jpeg图4344 未堆积的面积图 (Area Chart UnStacked)未堆积面积图用于可视化两个或更多个系列相对于彼此的进度(起伏)。 在下面的图表中,您可以清楚地看到随着失业中位数持续时间的增加,个人储蓄率会下降。 未堆积面积图表很好地展示了这种现象。
[*]# Import Data
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/economics.csv")
[*]
[*]# Prepare Data
[*]x = df['date'].values.tolist()
[*]y1 = df['psavert'].values.tolist()
[*]y2 = df['uempmed'].values.tolist()
[*]mycolors = ['tab:red', 'tab:blue', 'tab:green', 'tab:orange', 'tab:brown', 'tab:grey', 'tab:pink', 'tab:olive']
[*]columns = ['psavert', 'uempmed']
[*]
[*]# Draw Plot
[*]fig, ax = plt.subplots(1, 1, figsize=(16,9), dpi= 80)
[*]ax.fill_between(x, y1=y1, y2=0, label=columns, alpha=0.5, color=mycolors, linewidth=2)
[*]ax.fill_between(x, y1=y2, y2=0, label=columns, alpha=0.5, color=mycolors, linewidth=2)
[*]
[*]# Decorations
[*]ax.set_title('Personal Savings Rate vs Median Duration of Unemployment', fontsize=18)
[*]ax.set(ylim=)
[*]ax.legend(loc='best', fontsize=12)
[*]plt.xticks(x[::50], fontsize=10, horizontalalignment='center')
[*]plt.yticks(np.arange(2.5, 30.0, 2.5), fontsize=10)
[*]plt.xlim(-10, x[-1])
[*]
[*]# Draw Tick lines
[*]for y in np.arange(2.5, 30.0, 2.5):
[*]plt.hlines(y, xmin=0, xmax=len(x), colors='black', alpha=0.3, linestyles="--", lw=0.5)
[*]
[*]# Lighten borders
[*]plt.gca().spines["top"].set_alpha(0)
[*]plt.gca().spines["bottom"].set_alpha(.3)
[*]plt.gca().spines["right"].set_alpha(0)
[*]plt.gca().spines["left"].set_alpha(.3)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/eda3a44f1fd94b768f52650ad9c7e947.jpeg图4445 日历热力图 (Calendar Heat Map)与时间序列相比,日历地图是可视化基于时间的数据的备选和不太优选的选项。 虽然可以在视觉上吸引人,但数值并不十分明显。 然而,它可以很好地描绘极端值和假日效果。(『Python数据之道』注:需要安装 calmap 库)
[*]import matplotlib as mpl
[*]
[*]# pip install calmap
[*]# Python数据之道 备注
[*]import calmap
[*]
[*]# Import Data
[*]df = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/yahoo.csv", parse_dates=['date'])
[*]df.set_index('date', inplace=True)
[*]
[*]# Plot
[*]plt.figure(figsize=(16,10), dpi= 80)
[*]calmap.calendarplot(df['2014']['VIX.Close'], fig_kws={'figsize': (16,10)}, yearlabel_kws={'color':'black', 'fontsize':14}, subplot_kws={'title':'Yahoo Stock Prices'})
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/5b81ec90aefa4e328bca807f46639047.png图4546 季节图 (Seasonal Plot)季节图可用于比较上一季中同一天(年/月/周等)的时间序列。http://5b0988e595225.cdn.sohucs.com/images/20181228/5dd3cd17abcc41528dd3a7157747596b.jpeg图46七、分组 (Groups) 47 树状图 (Dendrogram)树形图基于给定的距离度量将相似的点组合在一起,并基于点的相似性将它们组织在树状链接中。
[*]import scipy.cluster.hierarchy as shc
[*]
[*]# Import Data
[*]df = pd.read_csv('https://raw.githubusercontent.com/selva86/datasets/master/USArrests.csv')
[*]
[*]# Plot
[*]plt.figure(figsize=(16, 10), dpi= 80)
[*]plt.title("USArrests Dendograms", fontsize=22)
[*]dend = shc.dendrogram(shc.linkage(df[['Murder', 'Assault', 'UrbanPop', 'Rape']], method='ward'), labels=df.State.values, color_threshold=100)
[*]plt.xticks(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/f42f253d1afb425bac049116e13b6912.jpeg图4748 簇状图 (Cluster Plot)簇状图 (Cluster Plot)可用于划分属于同一群集的点。 下面是根据USArrests数据集将美国各州分为5组的代表性示例。 此图使用“谋杀”和“攻击”列作为X和Y轴。 或者,您可以将第一个到主要组件用作X轴和Y轴。
[*]from sklearn.cluster import AgglomerativeClustering
[*]from scipy.spatial import ConvexHull
[*]
[*]# Import Data
[*]df = pd.read_csv('https://raw.githubusercontent.com/selva86/datasets/master/USArrests.csv')
[*]
[*]# Agglomerative Clustering
[*]cluster = AgglomerativeClustering(n_clusters=5, affinity='euclidean', linkage='ward')
[*]cluster.fit_predict(df[['Murder', 'Assault', 'UrbanPop', 'Rape']])
[*]
[*]# Plot
[*]plt.figure(figsize=(14, 10), dpi= 80)
[*]plt.scatter(df.iloc[:,0], df.iloc[:,1], c=cluster.labels_, cmap='tab10')
[*]
[*]# Encircle
[*]def encircle(x,y, ax=None, **kw):
[*]if not ax: ax=plt.gca()
[*]p = np.c_
[*]hull = ConvexHull(p)
[*]poly = plt.Polygon(p, **kw)
[*]ax.add_patch(poly)
[*]
[*]# Draw polygon surrounding vertices
[*]encircle(df.loc, df.loc, ec="k", fc="gold", alpha=0.2, linewidth=0)
[*]encircle(df.loc, df.loc, ec="k", fc="tab:blue", alpha=0.2, linewidth=0)
[*]encircle(df.loc, df.loc, ec="k", fc="tab:red", alpha=0.2, linewidth=0)
[*]encircle(df.loc, df.loc, ec="k", fc="tab:green", alpha=0.2, linewidth=0)
[*]encircle(df.loc, df.loc, ec="k", fc="tab:orange", alpha=0.2, linewidth=0)
[*]
[*]# Decorations
[*]plt.xlabel('Murder'); plt.xticks(fontsize=12)
[*]plt.ylabel('Assault'); plt.yticks(fontsize=12)
[*]plt.title('Agglomerative Clustering of USArrests (5 Groups)', fontsize=22)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/c6dfbb8c920f4d8485ff8a76d2ed23db.jpeg图4849 安德鲁斯曲线 (Andrews Curve)安德鲁斯曲线有助于可视化是否存在基于给定分组的数字特征的固有分组。 如果要素(数据集中的列)无法区分组(cyl),那么这些线将不会很好地隔离,如下所示。
[*]from pandas.plotting import andrews_curves
[*]
[*]# Import
[*]df = pd.read_csv("https://github.com/selva86/datasets/raw/master/mtcars.csv")
[*]df.drop(['cars', 'carname'], axis=1, inplace=True)
[*]
[*]# Plot
[*]plt.figure(figsize=(12,9), dpi= 80)
[*]andrews_curves(df, 'cyl', colormap='Set1')
[*]
[*]# Lighten borders
[*]plt.gca().spines["top"].set_alpha(0)
[*]plt.gca().spines["bottom"].set_alpha(.3)
[*]plt.gca().spines["right"].set_alpha(0)
[*]plt.gca().spines["left"].set_alpha(.3)
[*]
[*]plt.title('Andrews Curves of mtcars', fontsize=22)
[*]plt.xlim(-3,3)
[*]plt.grid(alpha=0.3)
[*]plt.xticks(fontsize=12)
[*]plt.yticks(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/8d73990de8524becb480bba634cd97c9.jpeg图4950 平行坐标 (Parallel Coordinates)平行坐标有助于可视化特征是否有助于有效地隔离组。 如果实现隔离,则该特征可能在预测该组时非常有用。
[*]from pandas.plotting import parallel_coordinates
[*]
[*]# Import Data
[*]df_final = pd.read_csv("https://raw.githubusercontent.com/selva86/datasets/master/diamonds_filter.csv")
[*]
[*]# Plot
[*]plt.figure(figsize=(12,9), dpi= 80)
[*]parallel_coordinates(df_final, 'cut', colormap='Dark2')
[*]
[*]# Lighten borders
[*]plt.gca().spines["top"].set_alpha(0)
[*]plt.gca().spines["bottom"].set_alpha(.3)
[*]plt.gca().spines["right"].set_alpha(0)
[*]plt.gca().spines["left"].set_alpha(.3)
[*]
[*]plt.title('Parallel Coordinated of Diamonds', fontsize=22)
[*]plt.grid(alpha=0.3)
[*]plt.xticks(fontsize=12)
[*]plt.yticks(fontsize=12)
[*]plt.show()
http://5b0988e595225.cdn.sohucs.com/images/20181228/ec6f1a6ba72a4fa992ea66650f55d3de.jpeg图50
页: [1]
查看完整版本: Matplotlib 可视化最有价值的 50 个图表(附完整 Python 源代码)