为什么我必须将python包导入每个类方法?

为什么我必须将python包导入每个类方法?,python,python-import,python-packaging,Python,Python Import,Python Packaging,我有一个类对象,对象中的一些方法需要python包(例如numpy)。如果在创建对象之前在主脚本中导入包,则对象中的方法无法识别已导入的包。为了解决这个问题,我必须在方法本身中导入所有必要的包,因为该方法被多次调用,所以效率似乎很低。是否有其他方法确保这些方法可以找到以前导入的包 下面是类对象: class CCState: def __init__(self, stateVector = None): self.fill_vol = 0 self.hea

我有一个类对象,对象中的一些方法需要python包(例如numpy)。如果在创建对象之前在主脚本中导入包,则对象中的方法无法识别已导入的包。为了解决这个问题,我必须在方法本身中导入所有必要的包,因为该方法被多次调用,所以效率似乎很低。是否有其他方法确保这些方法可以找到以前导入的包

下面是类对象:

class CCState:
    def __init__(self, stateVector = None):
        self.fill_vol = 0
        self.headspace_vol = 0
        self.temperature = 0
        self.pressure = 0
        self.flowin = 0
        self.flowout = 0
        self.product = 0
        self.viacell_attach = 0
        self.viacell_suspend = 0
        self.deadcell_attach = 0
        self.deadcell_suspend = 0
        self.headspace_temperature = 0
        self.hdgas_o2 = 0
        self.hdgas_n2 = 0
        self.hdgas_co2 = 0
        self.hdgas_ar = 0
        self.dsg_o2 = 0
        self.dsg_n2 = 0
        self.dsg_co2 = 0
        self.dsg_ar = 0
        self.glucose = 0
        self.glutamine = 0
        self.glutamate = 0
        self.lacticacid = 0
        self.lactate = 0
        self.ammonia = 0
        self.ammonium = 0
        self.bicarbonate = 0
        self.carbonate = 0
        self.cation = 0
        self.proton =  0
        self.anion = 0
        self.hepes = 0
        self.hepesion = 0
        self.hydroxyl = 0
        self.microcarrier = 0
        self.antifoam = 0
        self.sulfite = 0
        self.rDTT = 0
        self.oDTT = 0
        self.promoter = 0
        self.sulfiteacid = 0
        self.sulfate = 0
        self.bisulfite = 0
        self.fudgeacid = 0
        self.fudgeanion = 0
        self.fudgebase = 0
        self.fudgecation = 0
        self.viacell_attach2 = 0
        self.serum = 0
        self.tris = 0
        self.triscation = 0
        self.aceticacid =0
        self.acetate = 0
        self.h3po4 = 0
        self.dihydrogenphosphate = 0
        self.hydrogenphosphate = 0
        self.phosphate = 0
        self.names = [i for i in self.__dict__.keys() if i[:1] != '_']

        # If a vector has been passed, assign all parameters to values in the vector
        if stateVector is not None:
            for iName in range(0,len(self.names)):
                setattr(self,self.names[iName],stateVector[iName])
    def pH(self):
        """Return pH"""
        #from math import log
        return -log(max(10E-14, self.proton)*0.001,10);
如果运行此代码,则会出现错误“NameError:name'log'未定义”


首先,请给我们看一下你剧本的内容

如果在主脚本中导入库,则该库应在整个文件中都可用。使用
import lib
导入第二个名为lib.py的python脚本与将该文件中的内容复制到主脚本不同。但是,在lib.py中实现的库可以由主脚本的方法使用

主脚本

利比


Python的导入与C或PHP风格完全不同。Python没有全局名称空间,每个模块(或脚本)都是它自己的名称空间,因此每个模块都必须显式地导入它所依赖的libs

在您的情况下,解决方案很简单:在CCState.py模块中移动(或复制)所需的导入

另外,不要使用通配符导入(
from xxx import*
)-这肯定会导致维护噩梦。始终使用显式导入,即使库的文档告诉您可以使用通配符


最后,模块名称应该是所有较低的,而不是CamelCase。

您能发布您的代码吗?在文件开头导入python包应该允许在每个方法中使用包。实际上,不应该在方法或函数中进行导入。但是,如果你的类不在主脚本中,你必须在类的模块中导入numpy,而不是在主脚本中导入(好吧,如果你在主脚本中需要它,你当然也必须在那里导入numpy)。@Brunodesshuilliers我试图不在方法中导入,但我不确定为什么它找不到我导入的包。当您说导入到类的模块中时,您是否建议将导入添加到_init_u2;中?否,在定义类的模块顶部。我建议您学习完整的官方Python教程(也可以看看pep8)。根据您的描述,似乎我的代码应该可以工作,所以我不确定我做错了什么。请不要建议使用通配符导入。我不是建议这样做,我只是想说明它是如何工作的,因为您总是可以有一个模块导入其他模块。@Anteino只需在代码段中发布通配符导入,您建议使用它们。我感觉到您的意思,但这个小示例只是为了演示。实际上,
import lib
from lib import*
之间有什么区别?
from helper_functions import *
from scipy.integrate import ode
from math import exp, log
from scipy import interpolate
import numpy as np
from numpy.linalg import norm
from CCState import *
import chemical_reaction_model
import time

temp = CCState()
print(temp.pH())
from lib import *

x = [1, 2, 3]
x = numpy.array(x)

print(x)
import numpy