博客
关于我
读取excel文件并使用matplotlib绘图(含柱状图、柱状图加数值的显示和直方图)
阅读量:538 次
发布时间:2019-03-08

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

读取Excel数据并绘制折线图

以下代码示例展示了如何读取Excel文件并绘制折线图

import numpy as npimport matplotlib.pyplot as pltimport xlrd# 打开Excel文件workbook = xlrd.open_workbook('/home/myName/python_ws/excel_matplot_ws/read_plot/plot_data.xlsx')# 获取所有工作表名称worksheets = workbook.sheet_names()# 获取指定工作表mySheet = workbook.sheet_by_name(u'Sheet1')# 读取数据myData1 = []myData2 = []myData3 = []myData4 = []myData5 = []# 读取多行数据for c in range(1, 8):    myData1.append(mySheet.cell(1, c).value)for c in range(1, 8):    myData2.append(mySheet.cell(2, c).value)for c in range(1, 8):    myData3.append(mySheet.cell(3, c).value)for c in range(1, 8):    myData4.append(mySheet.cell(4, c).value)for c in range(1, 8):    myData5.append(mySheet.cell(5, c).value)# 绘制折线图x = range(0, 7)plt.title("测试结果")plt.xlabel("数值类型")plt.ylabel("数值大小:ms")# 绘制多条折线l1, = plt.plot(x, myData1, linestyle="-", linewidth=1.5)l2, = plt.plot(x, myData2, color="blue", linewidth=1.5, linestyle="-")l3, = plt.plot(x, myData3, color="red", linewidth=2.5, linestyle="--")l4, = plt.plot(x, myData4, color="cyan", linestyle="-")l5, = plt.plot(x, myData5, color="green", linestyle=":")# 添加图例plt.legend(handles=[l1, l2, l3, l4, l5], labels=['PoseOptimization', 'OptimizeSim3', 'LocalBundleAdjustment', 'OptimizeEssentialGraph', 'GlobalBundleAdjustment'], loc='best')plt.show()

柱状图或条形图

以下代码示例展示了如何绘制柱状图

import numpy as npimport matplotlib.pyplot as plt# 数据x1 = [1, 3, 7, 9]x2 = [2, 4, 6, 8, 10]y1 = [15, 3, 3, 3, 20]y2 = [6, 12, 22, 15, 12]# 绘制柱状图plt.bar(x1, y1, label='bar1')plt.bar(x2, y2, label='bar2')plt.xlabel('x轴')plt.ylabel('y轴')plt.title('柱形图')plt.legend()plt.show()

柱状图加数值注释

以下代码示例展示了如何在柱状图中添加数值注释

import numpy as npimport matplotlib.pyplot as pltdef auto_label(rects):    for rect in rects:        height = rect.get_height()        plt.text(rect.get_x() + rect.get_width()/2, height,                 f'{height}',                ha='center', va='bottom')def auto_text(rects):    for rect in rects:        plt.text(rect.get_x(), rect.get_height(),                 f'{rect.get_height()}',                 ha='left', va='bottom')# 数据men_means = [20, 34, 30, 35, 27]women_means = [25, 32, 34, 20, 25]index = np.arange(len(['L1', 'L2', 'L3', 'L4', 'L5']))# 绘制柱状图width = 0.2plt.figure(figsize=(10, 6))ax = plt.subplots()rect1 = ax.bar(index - width/2, men_means, color='lightcoral', width=width, label='Men')rect2 = ax.bar(index + width/2, women_means, color='springgreen', width=width, label='Women')ax.set_title('按性别统计分数')ax.set_xticks(ticks=index)ax.set_xticklabels(['L1', 'L2', 'L3', 'L4', 'L5'])ax.set_ylabel('分数')ax.set_ylim(0, 50)auto_label(rect1)auto_label(rect2)auto_text(rect1)auto_text(rect2)ax.legend(loc='upper right', frameon=False)plt.tight_layout()plt.show()

直方图

以下代码示例展示了如何绘制直方图

import numpy as npimport matplotlib.pyplot as plt# 数据population_ages = [22,55,62,45,21,22,34,42,42,4,99,102,110,120,121,122,130,111,115,112,80,75,65,54,44,43,42,48]bins = [0,10,20,30,40,50,60,70,80,90,100,110,120,130]# 绘制直方图plt.hist(population_ages, bins=bins, label='直方图')plt.xlabel('x轴')plt.ylabel('y轴')plt.title('直方图')plt.legend()plt.show()

以上代码示例展示了如何使用Python绘制不同类型的数据可视化图表,包括折线图、柱状图和直方图等。

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

你可能感兴趣的文章
php多线程
查看>>
PHP大数组循环-避免产生Notice或者是Warning
查看>>
PHP大数组过滤元素、修改元素性能分析
查看>>
PHP大文件切片下载代码
查看>>
php如何做表格,新手怎么制作表格
查看>>
php如何定义的数位置,php如何实现不借助IDE快速定位行数或者方法定义的文件和位置...
查看>>
RabbitMQ集群 - 普通集群搭建、宕机情况
查看>>
PHP如何生成唯一的数字ID
查看>>
PHP如何获取当前页面的最后修改时间
查看>>
PHP如何读取json数据
查看>>
PHP字符串
查看>>
PHP字符串递增
查看>>
php学习之基础语法
查看>>
RabbitMQ集群 - 仲裁队列、Raft协议(最详细的选举流程)
查看>>
PHP学习总结(11)——PHP入门篇之WAMPServer多站点配置
查看>>
PHP学习总结(12)——PHP入门篇之变量
查看>>
PHP学习总结(13)——PHP入门篇之常量
查看>>
PHP学习总结(14)——PHP入门篇之常用运算符
查看>>
PHP学习总结(1)——PHP入门篇之PHP可以做什么?
查看>>
PHP学习总结(2)——PHP入门篇之PHP代码标识
查看>>