博客
关于我
Python_matplotlib库绘制02(柱状图,饼状图)
阅读量:732 次
发布时间:2019-03-21

本文共 3464 字,大约阅读时间需要 11 分钟。

Matplotlib 绘图技巧:从柱状图到饼状图

Matplotlib 是一个强大的绘图库,支持多种类型的图表绘制,包括柱状图、饼状图、条形图等。在本文中,我们将逐步学习如何使用 Matplotlib 进行数据可视化。


柱状图

1. 简单柱状图

柱状图是最常用的数据可视化工具之一。下面是一个简单的柱状图示例:

import matplotlib.pyplot as pltnum_list = [1, 5, 6.5, 8, 11]plt.bar(range(len(num_list)), num_list)plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.show()

2. 改变柱状图颜色

为了更直观地展示数据,可以通过设置颜色来区分不同柱状图:

import matplotlib.pyplot as pltnum_list = [1, 5, 6.5, 8, 11]plt.bar(range(len(num_list)), num_list, color='rgbcy')plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.show()

3. 设置柱状图标签

为柱状图添加标签,使图表更加用户友好:

import matplotlib.pyplot as pltnum_list = [1, 5, 6.5, 8, 11]name_list = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']plt.bar(range(len(num_list)), num_list, color='rgbcy', tick_label=name_list)plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.show()

4. 堆叠柱状图

当需要同时比较多个数据系列时,可以使用堆叠柱状图:

import matplotlib.pyplot as pltnum_list = [1, 5, 6, 8, 11]num_list2 = [2, 3, 5, 1, 4]name_list = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']plt.bar(range(len(num_list)), num_list, color='b', tick_label=name_list, label='男')plt.bar(range(len(num_list)), num_list2, color='g', tick_label=name_list, label='女', bottom=num_list)plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.legend(loc='best')plt.show()

5. 横向条形图

如果想在水平方向展示数据,可以使用横向条形图:

import matplotlib.pyplot as pltnum_list = [1, 5, 6, 8, 11]num_list2 = [2, 3, 5, 1, 4]name_list = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']plt.barh(range(len(num_list)), num_list, color='b', tick_label=name_list, label='男')plt.barh(range(len(num_list)), num_list2, color='g', tick_label=name_list, label='女', left(num_list))plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.legend(loc='best')plt.show()

并列柱状图

1. 数据准备

为了制作并列柱状图,可以将每个柱子水平拉宽:

import matplotlib.pyplot as pltnum_list = [1, 5, 6.5, 8, 11]num_list2 = [2, 3, 5, 1, 4]name_list = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']x = list(range(len(num_list)))total_width = 0.8n = 2  #柱子数量width = total_width / n

2. 绘制并列柱状图

plt.bar(x, num_list, label='男', width=width)for i in range(len(x)):    x[i] = x[i] + widthplt.bar(x, num_list2, tick_label=name_list, label='女', width=width)plt.title("数据分布")plt.xlabel("x轴")plt.ylabel("y轴")plt.legend(loc='best')plt.show()

饼状图

1. 简单饼状图

饼状图适合展示不同部分所占的比例。以下是一个简单的饼状图示例:

import matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']  # 正常显示中文sizes = [10, 30, 20, 40]labels = ['A', 'B', 'C', 'D']plt.pie(sizes, labels=labels)plt.title("饼状图")plt.legend(loc='best')plt.show()

2. 饼状图到中心距离

要使饼状图的某一部分距离中心,可以设置 explode 参数:

import matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']sizes = [10, 30, 20, 40]labels = ['A', 'B', 'C', 'D']explode = (0, 0.1, 0.2, 0.1)plt.pie(sizes, labels=labels, explode=explode)plt.title("饼状图")plt.legend(loc='best')plt.show()

3. 设置饼状图颜色

你可以通过 colors 参数为饼状图添加颜色:

import matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']sizes = [10, 30, 20, 40]labels = ['A', 'B', 'C', 'D']colors = ['r', 'g', 'y', 'b']plt.pie(sizes, labels=labels, colors=colors)plt.title("饼状图")plt.legend(loc='best')plt.show()

4. 显示百分比

如果需要显示百分比,可以使用 autopct 参数:

import matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']sizes = [10, 30, 20, 40]labels = ['A', 'B', 'C', 'D']colors = ['r', 'g', 'y', 'b']plt.pie(sizes, labels=labels, colors=colors, autopct='%1.2f%%')plt.title("饼状图")plt.legend(loc='best')plt.show()

以上就是从简单柱状图到饼状图的 Matplotlib 绘图技巧总结。如果你有任何问题或需要进一步的帮助,欢迎在评论区留言!

转载地址:http://mzagz.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>