博客
关于我
读取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/

你可能感兴趣的文章
OpenCV 中的图像转换
查看>>
OpenCV 人脸识别 C++实例代码
查看>>
OpenCV 在 Linux 上的 python 与 anaconda 无法正常工作.收到未实现 cv2.imshow() 的错误
查看>>
Opencv 完美配置攻略 2014 (Win8.1 + Opencv 2.4.8 + VS 2013)上
查看>>
opencv 模板匹配, 已解决模板过大程序不工作的bug
查看>>
OpenCV 错误:(-215)size.width>0 &&函数imshow中的size.height>0
查看>>
opencv&Python——多种边缘检测
查看>>
opencv&python——高通滤波器和低通滤波器
查看>>
OpenCV-Python接口、cv和cv2的性能比较
查看>>
opencv1-加载、修改、保存图像
查看>>
opencv10-形态学操作
查看>>
opencv11-提取水平直线和垂直直线
查看>>
opencv12-图像金字塔
查看>>
opencv14-自定义线性滤波
查看>>
opencv15-边缘处理
查看>>
opencv16-Sobel算子
查看>>
opencv17-laplance算子
查看>>
opencv2-矩阵掩膜操作
查看>>
opencv20-霍夫圆检测
查看>>
opencv21-像素重映射
查看>>