2
В этой программе пока нет ошибки, но она создает пустой участок без каких-либо точек. Позднее я хочу изменить этот код, чтобы многие процессы могли работать параллельно, чтобы изменить общий график рассеяния matplotlib.Scatter Участок не строит с использованием менеджеров для многопроцессорности
from multiprocessing.managers import BaseManager, NamespaceProxy
from multiprocessing import Process
import matplotlib.pyplot as plt
import numpy as np
def plotter(res):
print(res.ax,res.fig)
res.ax.scatter(np.random.normal(0,20,(100,)),np.random.uniform(0,20,(100,)),s=1)
res.fig.savefig('man2.png')
class PlotClass():
fig = plt.figure()
ax = fig.add_subplot(111)
def __init__(self):
print('Test')
class MyManager(BaseManager):
pass
class MyAttProxy(NamespaceProxy):
# We need to expose the same __dunder__ methods as NamespaceProxy,
_exposed_ = ('__getattribute__', '__setattr__', '__delattr__')
MyManager.register('Plot', PlotClass,MyAttProxy)
if __name__ == '__main__':
manager = MyManager()
manager.start()
plotscat = manager.Plot()
pr = Process(target=plotter,args=(plotscat,))
pr.start()
pr.join()
plotscat.fig.savefig('fig.png')
Ваше решение не решает проблему. –