如何与另一个modu中的类共享main中创建的实例

2024-04-26 07:23:36 发布

您现在位置:Python中文网/ 问答频道 /正文

我在如何在模块之间共享类实例方面遇到了问题。下面不是实际的代码,它是我试图做的简化表示。有问题的变量是这个地块。如果将其设为全局,则会出现“global name not defined”类型错误。如果我不使用全局,那么shapes模块中的“draw”方法就找不到它。你知道吗

调用draw()方法并尝试执行“thePlot”方法“plot”时,我会出错。你知道吗

* Main module *****************
import matplotlib as plt
import plotter
import shapes

main():
    thePlot = plotter.plotter()
    cyl = shapes.cylinder(r, c, n, color)
    cyl.draw()
    plt.show()

* shapes module *******************
import main
import plotter

class shapes(self):
    def __init__(self):
        pass
    def cylinder(r, c, n, color):
    self.r = r
    self.c = c
    self.n = n
    self.color = color

def draw(self):
    self.x = calculate list of x coordinates
    self.y = calculate list of y coordinates
    self.z = calculate list of z coordinates
    global thePlot
    * This line causes the error
    thePlot.plot(self.x, self.y, self.z, self.color)

* plotter module ******************
import matplotlib as plt

class plotter(self):
    def __init__(self):
        self.fig = plt.figure()
        self.ax = fig.add_subplot(111, projection='3d')

    def plot(self, x, y, z, color):
        self.ax.plot_wireframe(x, y, z, color)

Tags: of方法importselfplotdefpltlist
2条回答
* Main module *****************
import matplotlib as plt
import plotter
import shapes

def main():
    global thePlot
    thePlot = plotter.plotter()
    cyl = shapes.cylinder(r, c, n, color)
    cyl.draw()
    plt.show()

还有这个:

global thePlot
* This line causes the error
thePlot.plot(self.x, self.y, self.z, self.color)

应该变成:

main.thePlot.plot(self.x, self.y, self.z, self.color)

条件是main.main()以前被调用过。你知道吗

我对matplotlib不太熟悉,但看起来有一个类似的问题Add cylinder to plot。这个代码怎么样?你知道吗

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D


fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

"""
def cyl():
    x = None
    y = None
    z = None
    return
"""
def cyl():
    x=np.linspace(-1, 1, 100)
    z=np.linspace(-2, 2, 100)
    Xc, Zc=np.meshgrid(x, z)
    Yc = np.sqrt(1-Xc**2)
    return Xc, Yc, Zc

Xc, Yc, Zc = cyl()

#draw parameters                                                                                                                                                          
rstride = 20
cstride = 10
ax.plot_surface(Xc, Yc, Zc, alpha=0.2, rstride=rstride, cstride=cstride)
ax.plot_surface(Xc, -Yc, Zc, alpha=0.2, rstride=rstride, cstride=cstride)

ax.set_xlabel("X")
ax.set_ylabel("Y")
ax.set_zlabel("Z")
plt.show()

相关问题 更多 >