Я извиняюсь за название, но я не мог придумать лучшего описания проблемы.У меня есть программа на основе Tkinter, у которой есть возможность для пользователя создать отчет в формате PDF, который состоит из обзора, за которым следуют некоторые подробные графики.Я знал, что по какой-то причине вся программа будет закрыта после завершения отчета в формате PDF, но я только недавно сел, чтобы действительно определить, что его вызвало.
Я обнаружил, что линия plt.close
на начальном обзорном графике, вызывает ли закрытие всей программы после написания отчета в формате pdf (это первая часть, которую я не совсем точно понимаю, если виноват plot.close
, почему весь модуль работает до завершения)?Во-вторых, почему это вообще происходит?
Минимальный пример, который я смог привести (с бессмысленными данными для графиков), приведен ниже, где, если строка, которой предшествует # THE CULPRIT
, комментируется, *Экземпляр 1008 * остается активным, но если оставить его как есть, экземпляр Tk()
будет закрыт.
import tkinter as tk
import matplotlib.pyplot as plt
import numpy as np
from matplotlib.backends.backend_pdf import PdfPages
from pathlib import Path
class Pdf(object):
def __init__(self, master):
self.master = master
pdf = PdfPages(Path.cwd() / 'demo.pdf')
self.pdf = pdf
def plot_initial(self):
fig = plt.figure(figsize=(8,6))
fig.add_subplot(111)
mu, sigma = 0, 0.1
s = np.random.normal(mu, sigma, 1000)
count, bins, ignored = plt.hist(s, 30, density=True)
plt.plot(bins, 1/(sigma * np.sqrt(2 * np.pi)) *
np.exp( - (bins - mu)**2 / (2 * sigma**2) ),
linewidth=2, color='r')
plt.title('Overview')
plt.xlabel('X')
plt.ylabel('Y')
self.pdf.savefig(fig)
# THE CULPRIT
plt.close(fig)
def plot_extra(self):
fig = plt.figure(figsize=(8,6))
fig.add_subplot(111)
mu, sigma = 0, 0.1
s = np.random.normal(mu, sigma, 1000)
count, bins, ignored = plt.hist(s, 30, density=True)
plt.plot(bins, 1/(sigma * np.sqrt(2 * np.pi)) *
np.exp( - (bins - mu)**2 / (2 * sigma**2) ),
linewidth=2, color='r')
plt.title('Extra')
plt.xlabel('X')
plt.ylabel('Y')
self.pdf.savefig(fig)
plt.close(fig)
def close(self):
self.pdf.close()
class MVE(object):
@classmethod
def run(cls):
root = tk.Tk()
MVE(root)
root.mainloop()
def __init__(self, master):
self.root = master
tk.Frame(master)
menu = tk.Menu(master)
master.config(menu=menu)
test_menu = tk.Menu(menu, tearoff=0)
menu.add_cascade(label='Bug', menu=test_menu)
test_menu.add_command(label='PDF', command=
self.generate_pdf)
def generate_pdf(self):
pdf = Pdf(self)
pdf.plot_initial()
for i in range(0,3):
pdf.plot_extra()
pdf.close()
if __name__ == "__main__":
MVE.run()
Версии установленных пакетов / база Python:
- Python 3.7.0
- Tkinter 8,6
- Matplotlib 2.2.3
- Numpy 1.15.1
Редактировать
Я обновил до Matplotlib 3.0.2 согласно предложению @ImportanceOfBeingErnest, однако проблема все еще остается.