京公网安备 11010802034615号
经营许可证编号:京B2-20210330
在Python中,matplotlib是一个广泛使用的绘图库。它可以用于创建各种类型的图表,包括折线图、散点图、条形图等等。当我们需要将多个数据系列绘制在同一张图中时,往往需要给每个系列指定不同的颜色。下面我将介绍如何在matplotlib中为不同系列指定颜色。
在matplotlib中,我们可以使用颜色编码来指定线条或点的颜色。常用的颜色编码有以下几种:
我们可以通过在绘图函数中传入颜色编码的参数来指定线条或点的颜色。例如,下面的代码会将三个数据系列分别绘制成蓝色、绿色和红色的线条:
import matplotlib.pyplot as plt
x = [1, 2, 3, 4, 5]
y1 = [1, 2, 3, 4, 5]
y2 = [1, 4, 9, 16, 25]
y3 = [5, 4, 3, 2, 1]
plt.plot(x, y1, 'b')
plt.plot(x, y2, 'g')
plt.plot(x, y3, 'r')
plt.show()
上面的代码中,我们通过在plot()函数中传入'b'、'g'和'r'参数来指定了每个数据系列的颜色。
除了使用颜色编码外,我们还可以使用十六进制颜色码来指定颜色。使用这种方法,我们可以得到更加精细的颜色控制,因为我们可以指定任何RGB颜色的组合。
要使用十六进制颜色码,我们需要在plot()函数中传递一个color参数,并将其设置为一个字符串,该字符串以'#'开头,后面跟着六个十六进制数字(每两个代表一个RGB颜色通道)。例如,下面的代码会将三个数据系列分别绘制成蓝色、浅绿色和深红色的线条:
import matplotlib.pyplot as plt
x = [1, 2, 3, 4, 5]
y1 = [1, 2, 3, 4, 5]
y2 = [1, 4, 9, 16, 25]
y3 = [5, 4, 3, 2, 1]
plt.plot(x, y1, color='#0000ff')
plt.plot(x, y2, color='#00ff80')
plt.plot(x, y3, color='#800000')
plt.show()
上面的代码中,我们分别使用了'#0000ff'、'#00ff80'和'#800000'作为颜色参数,以分别为三个数据系列指定颜色。
如果我们需要为多个数据系列选择一组相关的颜色,我们可以使用Colormap。Colormap是matplotlib中的一个类,它将连续的数值映射到一组颜色中,并且支持多个预定义的颜色方案。
使用Colormap,我们可以为每个数据系列指定一个数值,然后使用Colormap将这些数值映射到一组颜色中。例如,下面的代码将使用Colormap为三个数据系列指定颜色:
import matplotlib.pyplot as plt import numpy as np
x = [1, 2, 3, 4, 5]
y1 = [1,
2, 3, 4, 5] y2 = [1, 4, 9, 16, 25] y3 = [5, 4, 3, 2, 1]
colors = np.linspace(0, 1, len([y1, y2, y3]))
cm = plt.cm.Spectral
plt.plot(x, y1, color=cm(colors[0])) plt.plot(x, y2, color=cm(colors[1])) plt.plot(x, y3, color=cm(colors[2]))
sm = plt.cm.ScalarMappable(cmap=cm, norm=plt.Normalize(vmin=0, vmax=len([y1, y2, y3])-1)) sm._A = [] plt.colorbar(sm)
plt.show()
上面的代码中,我们首先使用`np.linspace()`函数创建了一个序列,该序列的长度等于数据系列的数量。然后,我们使用`plt.cm.Spectral`颜色方案创建了一个Colormap对象,并将该对象存储在变量`cm`中。接下来,我们分别为每个数据系列指定了一个颜色,其中颜色是通过将对应位置的序列值映射到Colormap中得到的。最后,我们使用`plt.colorbar()`函数在图例中显示了颜色条。 ## 总结 在matplotlib中为不同数据系列指定颜色可以通过多种方式实现。我们可以使用颜色编码、十六进制颜色码或Colormap来指定颜色。使用Colormap时,我们可以为每个数据系列指定一个数值,并使用Colormap将这些数值映射到一组颜色中。无论选择哪种方法,都要确保为每个数据系列指定一个明显的颜色,以便轻松区分它们。
你是否渴望进一步提升数据可视化的能力,让数据展示更加专业、高效呢?现在,有一门绝佳的课程能满足你的需求 ——Python 数据可视化 18 讲(PyEcharts、Matplotlib、Seaborn)。
学习入口:https://edu.cda.cn/goods/show/3842?targetId=6751&preview=0
这门课程完全免费,且学习有效期长期有效。由 CDA 数据分析研究院的张彦存老师精心打造,他拥有丰富的实战经验,能将复杂知识通俗易懂地传授给你。课程深入讲解 matplotlib、seaborn、pyecharts 三大主流 Python 可视化工具,带你从基础绘图到高级定制,还涵盖多元图表类型和各类展示场景。无论是数据分析新手想要入门,还是有基础的从业者希望提升技能,亦或是对数据可视化感兴趣的爱好者,都能从这门课程中收获满满。点击课程链接,开启你的数据可视化进阶之旅,让数据可视化成为你职场晋升和探索数据世界的有力武器!
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在金融行业的数字化转型进程中,SQL作为数据处理与分析的核心工具,贯穿于零售银行、证券交易、保险理赔、支付结算等全业务链条 ...
2025-12-24在数据分析领域,假设检验是验证“数据差异是否显著”的核心工具,而独立样本t检验与卡方检验则是其中最常用的两种方法。很多初 ...
2025-12-24在企业数字化转型的深水区,数据已成为核心生产要素,而“让数据可用、好用”则是挖掘数据价值的前提。对CDA(Certified Data An ...
2025-12-24数据分析师认证考试全面升级后,除了考试场次和报名时间,小伙伴们最关心的就是报名费了,报 ...
2025-12-23CDA中国官网是全国统一的数据分析师认证报名网站,由认证考试委员会与持证人会员、企业会员以及行业知名第三方机构共同合作,致 ...
2025-12-23在Power BI数据可视化分析中,矩阵是多维度数据汇总的核心工具,而“动态计算平均值”则是矩阵分析的高频需求——无论是按类别计 ...
2025-12-23在SQL数据分析场景中,“日期转期间”是高频核心需求——无论是按日、周、月、季度还是年度统计数据,都需要将原始的日期/时间字 ...
2025-12-23在数据驱动决策的浪潮中,CDA(Certified Data Analyst)数据分析师的核心价值,早已超越“整理数据、输出报表”的基础层面,转 ...
2025-12-23在使用Excel数据透视表进行数据分析时,我们常需要在透视表旁添加备注列,用于标注数据背景、异常说明、业务解读等关键信息。但 ...
2025-12-22在MySQL数据库的性能优化体系中,索引是提升查询效率的“核心武器”——一个合理的索引能将百万级数据的查询耗时从秒级压缩至毫 ...
2025-12-22在数据量爆炸式增长的数字化时代,企业数据呈现“来源杂、格式多、价值不均”的特点,不少CDA(Certified Data Analyst)数据分 ...
2025-12-22在企业数据化运营体系中,同比、环比分析是洞察业务趋势、评估运营效果的核心手段。同比(与上年同期对比)可消除季节性波动影响 ...
2025-12-19在数字化时代,用户已成为企业竞争的核心资产,而“理解用户”则是激活这一资产的关键。用户行为分析系统(User Behavior Analys ...
2025-12-19在数字化转型的深水区,企业对数据价值的挖掘不再局限于零散的分析项目,而是转向“体系化运营”——数据治理体系作为保障数据全 ...
2025-12-19在数据科学的工具箱中,析因分析(Factor Analysis, FA)、聚类分析(Clustering Analysis)与主成分分析(Principal Component ...
2025-12-18自2017年《Attention Is All You Need》一文问世以来,Transformer模型凭借自注意力机制的强大建模能力,在NLP、CV、语音等领域 ...
2025-12-18在CDA(Certified Data Analyst)数据分析师的时间序列分析工作中,常面临这样的困惑:某电商平台月度销售额增长20%,但增长是来 ...
2025-12-18在机器学习实践中,“超小数据集”(通常指样本量从几十到几百,远小于模型参数规模)是绕不开的场景——医疗领域的罕见病数据、 ...
2025-12-17数据仓库作为企业决策分析的“数据中枢”,其价值完全依赖于数据质量——若输入的是缺失、重复、不一致的“脏数据”,后续的建模 ...
2025-12-17在CDA(Certified Data Analyst)数据分析师的日常工作中,“随时间变化的数据”无处不在——零售企业的每日销售额、互联网平台 ...
2025-12-17