未找到 Matplotlib Qt5Agg 后端
Posted
技术标签:
【中文标题】未找到 Matplotlib Qt5Agg 后端【英文标题】:Matplotlib Qt5Agg backend not found 【发布时间】:2018-07-20 14:09:09 【问题描述】:我编写了一个 Python 3.6 程序,它读取 UTM 坐标的 .txt 文件,将它们按逆时针顺序排序,使用 matplotlib 在图形上显示坐标,然后将坐标写入桌面上的 .txt 文件。当我在 spyder 中运行它时它工作正常,这是我一直在使用的 IDE,但是当我使用 cx_Freeze(通过构建我的 python 文件)将它转换为 exe 并尝试运行它时,我收到以下错误: ModuleNotFoundError:没有名为“matplotlib.backends.backend_qt5agg”的模块 我尝试通过以下方式安装 Qt5 后端: 点安装 PyQt5 以及更新 cx_Freeze。任何帮助将非常感激。我仍然是 Python 以及一般编程的初学者,所以如果我的解释不够清楚,我深表歉意。下面是我的主要 Python 脚本代码
import matplotlib
matplotlib.use('Qt5Agg')
import matplotlib.pyplot as plt
import math as math
import tkinter as tk
from tkinter.filedialog import askopenfilename
import time
def findFilename():
root = tk.Tk()
#root.withdraw()
filename = askopenfilename()
root.destroy()
return(filename)
def findSize(cnt, filename):
#number of lines in file
with open(filename) as f:
for line in f:
cnt = cnt+1;
return cnt;
def findChar(filename):
file = open(filename, "r")
char = ""
lines = file.read()
if(lines.find(" ") == -1):
char = ","
else:
char = " "
return(char)
def inputArr(cnt, arrX, arrY, arrZ, filename, char):
file = open(filename, "r")
num1 = 0
num2 = 0
num3 = 0
place1 = 0
place2 = 0
place3 = 0
for i in range(0, cnt):
num = file.readline()
place1 = num.find(char)
num1 = num[:place1]
num = num[place1 + 1:]
place2 = num.find(char)
num2 = num[:place2]
num = num[place2+1:]
place3 = num.find(char)
num3 = num[:place3]
arrX.append(float(num1))
arrY.append(float(num2))
arrZ.append(float(num3))
return(arrX, arrY, arrZ)
def drawPath(arrX, arrY, label, cnt):
plt.plot(arrX, arrY, '-ok', color = 'red')
plt.xlabel("X coordinates")
plt.ylabel("Y coordinates")
plt.title("Loop path")
plt.show()
for i in range(0,cnt):
label.append(str(i))
for i, txt in enumerate(label):
plt.annotate(txt, (arrX[i], arrY[i]))
def findCenter(arrX, arrY, cnt):
xCenter = 0
yCenter = 0
for i in range(0,cnt):
xCenter += arrX[i]
yCenter += arrY[i]
xCenter /= cnt
yCenter /= cnt
return(xCenter, yCenter)
def moveToCenter(arrX, arrY, arrX1, arrY1, xCenter, yCenter, cnt):
for i in range(0,cnt):
arrX1.append(arrX[i] - xCenter)
arrY1.append(arrY[i] - yCenter)
return(arrX1, arrY1)
def calculateTheta(arrX1, arrY1, arrTheta, cnt):
for i in range(0,cnt):
arrTheta.append(math.atan2(arrY1[i], arrX1[i]))
# print(arrTheta[0])
return(arrTheta)
def sortPoints(arrTheta, arrX, arrY, arrZ, cnt):
minimum = 0
for i in range(0,cnt-1):
minimum = i
for j in range(i + 1, cnt):
if(arrTheta[j] < arrTheta[minimum]):
minimum = j
arrTheta[minimum], arrTheta[i] = arrTheta[i], arrTheta[minimum]
arrX[minimum], arrX[i] = arrX[i], arrX[minimum]
arrY[minimum], arrY[i] = arrY[i], arrY[minimum]
arrZ[minimum], arrZ[i] = arrZ[i], arrZ[minimum]
def writeFile(arrX, arrY, arrZ, cnt, char):
moment = time.strftime("%Y-%b-%d__%H_%M_%S",time.localtime())
file = open("C:\\Users\\natha\\Desktop\\sorted" + str(moment) + ".txt", "w")
num = ""
for i in range(0,cnt):
if(i < 10):
num = "0"
else:
num = ""
file.write("<" + "L" + num + str(i) + ">" + " " + str(arrX[i]) + char +
str(arrY[i]) + char + str(arrZ[i]) + char + "\n")
def main():
cnt = 0
arrX = []
arrY = []
arrZ = []
label = []
arrX1 = []
arrY1 = []
arrTheta = []
xCenter = 0
yCenter = 0
char = ""
filename = findFilename()
char = findChar(filename)
cnt = findSize(cnt, filename)
findChar(filename)
inputArr(cnt, arrX, arrY, arrZ, filename, char)
xCenter, yCenter = findCenter(arrX, arrY, cnt)
arrX1, arrY1 = moveToCenter(arrX, arrY, arrX1, arrY1, xCenter, yCenter, cnt)
arrTheta = calculateTheta(arrX1, arrY1, arrTheta, cnt)
#arrX, arrY, arrZ = randomPoints(arrX, arrY, arrZ, cnt)
sortPoints(arrTheta, arrX, arrY, arrZ, cnt)
writeFile(arrX, arrY, arrZ, cnt, char)
drawPath(arrX, arrY, label, cnt)
main()
还有我的 setup.py 文件
from cx_Freeze import setup, Executable
import sys
import os.path
os.environ['TCL_LIBRARY'] = r'C:\Users\natha\Anaconda3\tcl\tcl8.6'
os.environ['TK_LIBRARY'] = r'C:\Users\natha\Anaconda3\tcl\tk8.6'
additional_mods = ['numpy.core._methods', 'numpy.lib.format']
setup(name='loopProgram',
version='0.4',
description='xyz script',
options = 'build_exe': 'includes': additional_mods,
executables = [Executable('loopProgram.py')]
)
【问题讨论】:
您尝试过“TkAgg”后端吗?我不是 100% 确定,但“TkAgg”似乎更适合 Tk 应用程序。 【参考方案1】:对于 OpenSUSE,我发现上述答案不起作用。我尝试了所有各种后端,但没有任何显示。我没有从运行的脚本中得到任何错误输出,而且 plot.show() 函数甚至没有阻塞控制台。如this thread 所述,plot.savefig()
正确使用时不会出现问题
This link 表明我需要在安装matplotlib
之前添加tk-devel
。使用 Zypper 我安装了 tk-devel
,卸载了 python3-matplotlib
,重新安装了 matplotlib,这对我有用。
【讨论】:
【参考方案2】:安装缺少的 matplotlib qt5 后端 sudo apt-get install python-matplotlib-qt5
获取 Matplotlib 配置文件路径: Python 导入 matplotlib matplotlib.matplotlib_fname() u'/usr/lib64/python3.6/site-packages/matplotlib/mpl-data/matplotlibrc' 在配置文件中,将后端更改为 qt5agg vi /usr/lib64/python3.6/site-packages/matplotlib/mpl-data/matplotlibrc
将行改为:
后端:qt5agg
【讨论】:
您好,感谢您的回复。当我打开 matplotlibrc 文件时,我的后端默认是 qt5agg。它仍然不起作用。我正在使用 Windows 10,如果这有帮助的话。E: Unable to locate package python-matplotlib-qt5
on ubuntu20.04【参考方案3】:
您是否尝试添加以下行
import matplotlib.backends.backend_qt5agg
在您的主要 Python 脚本中(或在您的脚本中使用的任何其他适当模块中)“强制”cx_Freeze 包含此模块?
【讨论】:
澄清 cx_Freeze 如何决定要包含的内容可能会有所帮助(以及为什么 qt5agg 在这种情况下是“隐藏”导入)。 @SNygard 我完全同意你的看法,但我不知道答案。在开发应用程序时,我注意到我需要明确地import matplotlib.backends.backend_ps
才能将绘图保存为冻结应用程序中的附言。 cx_Freeze 包含其他后端(例如 PNG),无需显式导入。【参考方案4】:
我知道这是一个旧线程,但我最近在使用 Spyder 5 时遇到了这个问题。 我正在使用 OpenSUSE,我通过安装 python38-matplotlib-qt5 解决了这个问题
zypper in python38-matplotlib-qt5
不过,请先检查您的 python 版本!!! 这可能只适用于 python3.8 及更高版本。
【讨论】:
以上是关于未找到 Matplotlib Qt5Agg 后端的主要内容,如果未能解决你的问题,请参考以下文章
如何防止PyCharm覆盖matplotlib中设置的默认后端?