为啥我的折线图没有显示在 GUI 上

Posted

技术标签:

【中文标题】为啥我的折线图没有显示在 GUI 上【英文标题】:Why isn't my line graph showing up on GUI为什么我的折线图没有显示在 GUI 上 【发布时间】:2018-04-18 22:49:18 【问题描述】:

这是一个在单击按钮时被调用的函数。它应该显示一个折线图,为什么它没有显示出来。

def plotk2(self):
#----------------------------------------------------------------Data
    temp=full_dataset[['country_txt','iyear','nkill']]
    text = self.k_count.currentText()
    temp = temp[temp['country_txt'].str.match(text)]
    temp2=temp.groupby(['iyear'])['nkill'].count()
    temp2=temp2.to_frame()
    temp2['iyear']=temp2.index
#----------------------------------------------------------------
    self.figure.clear()

    ax = self.figure.add_subplot(111)
    plt.plot( 'nkill', 'iyear', data=temp2)
    #ax.axis('off')


    plt.show()

    self.canvas.draw()

【问题讨论】:

【参考方案1】:

如果你想在PyQt 上绘图,你必须使用FigureCanvas,而不是matplotlib.pyplot,所以如果你使用plt.plot(),你将不会绘制任何东西。

在您的情况下,类似的示例是:

import sys
import pandas as pd

import matplotlib
matplotlib.use('Qt5Agg')
from PyQt5 import QtCore, QtWidgets
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
from matplotlib.figure import Figure

class Widget(QtWidgets.QWidget):
    def __init__(self, *args, **kwargs):
        QtWidgets.QWidget.__init__(self, *args, **kwargs)
        self.figure = Figure(figsize=(5, 4), dpi=100)
        self.canvas = FigureCanvas(self.figure)
        self.canvas.setSizePolicy(QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Expanding)

        button = QtWidgets.QPushButton("random plot")
        button.clicked.connect(self.plot)

        lay = QtWidgets.QVBoxLayout(self)
        lay.addWidget(self.canvas)
        lay.addWidget(button)
        self.plot()

    def plot(self):
        self.figure.clear()
        ax = self.figure.add_subplot(111)
        d = 'nkill': [1, 2, 4, 5, 6], 'iyear': [3, 4, 5, 5, 5]
        df = pd.DataFrame(data=d)
        ax.plot('nkill', 'iyear', data=df)
        # ax.axis('off')
        self.canvas.draw()

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())

【讨论】:

以上是关于为啥我的折线图没有显示在 GUI 上的主要内容,如果未能解决你的问题,请参考以下文章

D3 JS中的折线图路径未正确显示

Grafana:x 轴上没有日期时间的折线图

如何使用 Chart.js 向我的折线图添加点击事件

OBIEE:数据透视表中的折线图

如何使echarts的折线图x轴隔两个数据进行显示

excel中的折线图和散点图出来的斜率怎么不一样