Python数据可视化:象限图的应用
2021-03-30 12:26
标签:项目 key trim 联系我们 图库 图像 line 场景 别人 前言 本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。 萝卜 | 作者 数据不吹牛 | 来源 Python 的绘图功能非常强大,如果能将已有的绘图库的各种复杂操作汇总在一个自己写的函数甚至是库/包中,并实现一行代码就调用并实现复杂的绘图功能,那就更是如虎添翼。 今天,我们就来讲讲一学就会的象限图。 上图学名叫波士顿矩阵分析图,大白话四象限图。这种图经常用于两个维度的散点图中,根据特定的分割线(均值,目标值,实际值等)将数据分为四类,使人一目了然。 常用的场景为分析两个维度的变化比如:比较商品的库存天数和库存周转率,充值人数和每付费用户平均收益,购物篮系数和购物篮数量等。 如何使用 Python 画出此图是本文的目标,事不宜迟,赶快开始! 任何复杂的 Python 绘图都不是一蹴而就的,而是先画出基础图形,后在此基础上按需添加元素并优化而成。这里以一组城市经济数据为例来讲解绘图步骤 基础散点图 简洁又朴素的散点图,仅需一行代码。离期望成图还差几步 图像优化 成图如下: 从上图可以看出: 当然,如果我们通过添加数量更多的定制线也可以实现常用的九宫格图 《数据化管理》库存天数与销售数量分析 最后总结一下,Python 的一些绘图方法、参数看似琐碎,但积累到一定程度后,便可以发现许多技巧都存在共通之处。小事情重复做也会成为大麻烦,所以高手都懂得分类处理。 贯通了 3 个核心,我们才能省时省事,成为别人眼中的高手: 所以我们可以将四象限图的绘制方法封装成自己的函数以供快捷调用,篇幅原因就不多展示了。 上文核心代码如下: PS:如有需要Python学习资料的小伙伴可以加下方的群去找免费管理员领取 可以免费领取源码、项目实战视频、PDF文件等 Python数据可视化:象限图的应用 标签:项目 key trim 联系我们 图库 图像 line 场景 别人 原文地址:https://www.cnblogs.com/hhh188764/p/13583068.htmldf = pd.read_csv(‘data.csv‘)
df; df.plot(kind=‘scatter‘, x=‘经济总量水平‘, y=‘人均水平‘)
import matplotlib.pyplot as plt
# 为每个点添加对应的城市名称
plt.figure(figsize=(10, 8))
# 基础散点图:这里需要单独拆开 x,y 轴和希望配对的标签,为下面的轮子做准备
x, y = df[‘经济总量水平‘], df[‘人均水平‘]
label = df[‘area‘]
plt.scatter(x, y)
plt.xlabel(‘经济总量水平‘); plt.ylabel(‘人均水平‘)
# 对散点图中的每一个点进行文字标注
## 固定代码,无需深究,拿来即用
for a,b,l in zip(x,y,label): # zip 拉链函数将其配对组合
plt.text(a, b+0.1, ‘%s.‘ % l, ha=‘center‘, va=‘bottom‘,
fontsize=14)
# 0.1 向上轻微偏移
# 添加特定分割线
## vlines: vertical 垂直于 x 轴的线,在变量‘经济总量‘的均值处开始画,
## y 轴的范围[1.5, 3]
plt.vlines(x=df[‘经济总量水平‘].mean(), ymin=-1.5, ymax=3,
colors=‘red‘, linewidth=2)
plt.hlines(y=df[‘人均水平‘].mean(), xmin=-4, xmax=6,
colors=‘red‘, linewidth=2)
# 背景网格
plt.grid(True)
# 定制需求:隐去四周的边框线条
# sns.despine(trim=True, left=True, bottom=True)