matplotlib绑定到PyQt5(有菜单)

简介:

稍微复杂地实现matplotlib绑定到PyQt5(有菜单)

 

【知识点】

 

 

 import matplotlib
 matplotlib.use("Qt5Agg")

 

 

【效果图】

 

【源代码】

复制代码
  1 import sys
  2 import random
  3 
  4 import matplotlib
  5 matplotlib.use("Qt5Agg")
  6 
  7 from PyQt5 import QtCore
  8 from PyQt5.QtWidgets import QApplication, QMainWindow, QMenu, QVBoxLayout, QSizePolicy, QMessageBox, QWidget
  9 
 10 from numpy import arange, sin, pi
 11 from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
 12 from matplotlib.figure import Figure
 13 
 14 
 15 class MyMplCanvas(FigureCanvas):
 16     """这是一个窗口部件,即QWidget(当然也是FigureCanvasAgg)"""
 17     def __init__(self, parent=None, width=5, height=4, dpi=100):
 18         fig = Figure(figsize=(width, height), dpi=dpi)
 19         self.axes = fig.add_subplot(111)
 20         # 每次plot()调用的时候,我们希望原来的坐标轴被清除(所以False)
 21         self.axes.hold(False)
 22 
 23         self.compute_initial_figure()
 24 
 25         #
 26         FigureCanvas.__init__(self, fig)
 27         self.setParent(parent)
 28 
 29         FigureCanvas.setSizePolicy(self,
 30                                    QSizePolicy.Expanding,
 31                                    QSizePolicy.Expanding)
 32         FigureCanvas.updateGeometry(self)
 33 
 34     def compute_initial_figure(self):
 35         pass
 36 
 37 class MyStaticMplCanvas(MyMplCanvas):
 38     """静态画布:一条正弦线"""
 39     def compute_initial_figure(self):
 40         t = arange(0.0, 3.0, 0.01)
 41         s = sin(2*pi*t)
 42         self.axes.plot(t, s)
 43 
 44 
 45 class MyDynamicMplCanvas(MyMplCanvas):
 46     """动态画布:每秒自动更新,更换一条折线。"""
 47     def __init__(self, *args, **kwargs):
 48         MyMplCanvas.__init__(self, *args, **kwargs)
 49         timer = QtCore.QTimer(self)
 50         timer.timeout.connect(self.update_figure)
 51         timer.start(1000)
 52 
 53     def compute_initial_figure(self):
 54         self.axes.plot([0, 1, 2, 3], [1, 2, 0, 4], 'r')
 55 
 56     def update_figure(self):
 57         # 构建4个随机整数,位于闭区间[0, 10]
 58         l = [random.randint(0, 10) for i in range(4)]
 59 
 60         self.axes.plot([0, 1, 2, 3], l, 'r')
 61         self.draw()
 62 
 63 class ApplicationWindow(QMainWindow):
 64     def __init__(self):
 65         QMainWindow.__init__(self)
 66         self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
 67         self.setWindowTitle("程序主窗口")
 68 
 69         self.file_menu = QMenu('&File', self)
 70         self.file_menu.addAction('&Quit', self.fileQuit,
 71                                  QtCore.Qt.CTRL + QtCore.Qt.Key_Q)
 72         self.menuBar().addMenu(self.file_menu)
 73 
 74         self.help_menu = QMenu('&Help', self)
 75         self.menuBar().addSeparator()
 76         self.menuBar().addMenu(self.help_menu)
 77 
 78         self.help_menu.addAction('&About', self.about)
 79 
 80         self.main_widget = QWidget(self)
 81 
 82         l = QVBoxLayout(self.main_widget)
 83         sc = MyStaticMplCanvas(self.main_widget, width=5, height=4, dpi=100)
 84         dc = MyDynamicMplCanvas(self.main_widget, width=5, height=4, dpi=100)
 85         l.addWidget(sc)
 86         l.addWidget(dc)
 87 
 88         self.main_widget.setFocus()
 89         self.setCentralWidget(self.main_widget)
 90         # 状态条显示2秒
 91         self.statusBar().showMessage("matplotlib 万岁!", 2000)
 92 
 93     def fileQuit(self):
 94         self.close()
 95 
 96     def closeEvent(self, ce):
 97         self.fileQuit()
 98 
 99     def about(self):
100         QMessageBox.about(self, "About",
101         """embedding_in_qt5.py example
102         Copyright 2015 BoxControL
103 
104         This program is a simple example of a Qt5 application embedding matplotlib
105         canvases. It is base on example from matplolib documentation, and initially was
106         developed from Florent Rougon and Darren Dale.
107 
108         http://matplotlib.org/examples/user_interfaces/embedding_in_qt4.html
109 
110         It may be used and modified with no restriction; raw copies as well as
111         modified versions may be distributed without limitation.
112         """
113         )
114 
115 if __name__ == '__main__':
116     app = QApplication(sys.argv)
117 
118     aw = ApplicationWindow()
119     aw.setWindowTitle("PyQt5 与 Matplotlib 例子")
120     aw.show()
121     #sys.exit(qApp.exec_())
122     app.exec_()
复制代码

 

本文转自罗兵博客园博客,原文链接:http://www.cnblogs.com/hhh5460/p/4322652.html ,如需转载请自行联系原作者
相关文章
|
Python
PyQt5嵌入matplotlib动画
1 # -*- coding: utf-8 -*- 2 3 import sys 4 from PyQt5 import QtWidgets 5 6 import numpy as np 7 from matplotlib.
1840 0
|
Python
PyQt5 结合 matplotlib 时,如何显示其 NavigationToolbar
本文目的:展示 PyQt5 结合 matplotlib 时,如何显示其 NavigationToolbar。 本人搜遍所有网络无果,没办法,查看PyQt5源代码,最终才搞明白。。。特此留记。   〇、PyQt4 与 PyQt5 导入 NavigationToolbar 时的区别(去掉两个agg) # PyQt4 版本(网传) #from matplotlib.
1212 0
|
2月前
|
Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
|
2月前
|
数据可视化 数据挖掘 Linux
震撼发布!Python数据分析师必学,Matplotlib与Seaborn数据可视化实战全攻略!
在数据科学领域,数据可视化是连接数据与洞察的桥梁,能让复杂的关系变得直观。本文通过实战案例,介绍Python数据分析师必备的Matplotlib与Seaborn两大可视化工具。首先,通过Matplotlib绘制基本折线图;接着,使用Seaborn绘制统计分布图;最后,结合两者在同一图表中展示数据分布与趋势,帮助你提升数据可视化技能,更好地讲述数据故事。
44 1
|
2月前
|
存储 数据可视化 数据挖掘
揭秘!Matplotlib与Seaborn联手,如何让Python数据分析结果一目了然,惊艳全场?
在数据驱动时代,高效直观地展示分析结果至关重要。Python中的Matplotlib与Seaborn是两大可视化工具,结合使用可生成美观且具洞察力的图表。本文通过分析某电商平台的商品销量数据集,展示了如何利用这两个库揭示商品类别与月份间的销售关系及价格对销量的影响。首先使用Matplotlib绘制月份销量分布直方图,再借助Seaborn的箱线图进一步探索不同类别和价格区间下的销量稳定性。
57 10
|
2月前
|
数据可视化 Python
Python中的数据可视化:使用Matplotlib绘制图表
【9月更文挑战第11天】在这篇文章中,我们将探索如何使用Python的Matplotlib库来创建各种数据可视化。我们将从基本的折线图开始,然后逐步介绍如何添加更多的功能和样式,以使您的图表更具吸引力和信息量。无论您是数据科学家、分析师还是任何需要将数据转化为视觉形式的专业人士,这篇文章都将为您提供一个坚实的起点。让我们一起潜入数据的海洋,用视觉的力量揭示其背后的故事。
49 16
|
2月前
|
数据可视化 数据挖掘 API
使用Python进行数据可视化:探索Matplotlib和Seaborn库
【9月更文挑战第19天】在数据科学领域,将复杂的数据集转换成直观、易懂的图形是一项基本而关键的技能。本文旨在通过Python编程语言介绍两个强大的数据可视化库——Matplotlib和Seaborn,以及它们如何帮助数据分析师和研究人员揭示数据背后的故事。我们将从基础概念讲起,逐步深入到高级技巧,确保无论读者的背景如何,都能获得必要的知识和启发,以在自己的项目中实现有效的数据可视化。