所以我不断收到这个错误,当我用谷歌搜索时,最常见的解决方法是确保一个类的所有方法都将“self”作为第一个参数。这是错误:
文件“C:\Users\me\Documents\Project\code\model\TrainEvent.py”,第 9 行,位于
NameError: global name 'self' is not definedPress any key to continue 。 . .
除了我所有的方法都将 self 作为第一个参数之外,这似乎是一个简单的修复的常见错误。然后我意识到回溯只是指向声明类名的那一行。它没有指向我用 self 调用方法的那一行。很久以前就出现了这个错误。事实上,它似乎在导入时被提升。这是 TrainEvent.py。
from xml.etree.ElementTree import Element
class TrainEvent(object):
def __init__(self, element):
self._element = element
self.MsgId = self.__tagGrab('MsgId')
self.MsgTime = self.__tagGrab('MsgTime')
self.Offset = self.__tagGrab('Offset')
self.TranId = self.__tagGrab('TranId')
self.Portal = self.__tagGrab('Portal')
moveElem = self._element.find('Move')
self.StartTime = self.__tagGrab('StartTime', moveElem)
self.EndTime = self.__tagGrab('EndTime', moveElem)
self.Type = self.__tagGrab('Type', moveElem)
carElem = self._element.find('Car')
self.Name = self.__tagGrab('Name', carElem)
self.UniqueId = self.__tagGrab('UniqueId', carElem)
self.Orientation = self.__tagGrab('Orientation', carElem)
self.Wells = self.__tagGrab('Wells', carElem)
self.Axles = self.__tagGrab('Axles', carElem)
self.Length = self.__tagGrab('Length', carElem)
self.IsEngine = self.__tagGrab('IsEngine', carElem)
self.IsGhost = self.__tagGrab('IsGhost', carElem)
def getTree(self):
aTree = Element('ApsMessage')
self.__addTag(aTree, 'MsgId', self.MsgId)
self.__addTag(aTree, 'MsgTime', self.MsgTime)
self.__addTag(aTree, 'Offset', self.Offset)
self.__addTag(aTree, 'TranId', self.TranId)
self.__addTag(aTree, 'Portal', self.Portal)
moveElem = Element('Move')
self.__addTag(moveElem, 'StartTime', self.StartTime)
self.__addTag(moveElem, 'EndTime', self.EndTime)
self.__addTag(moveElem, 'Type', self.Type)
aTree.append(moveElem)
carElem = Element('Car')
self.__addTag(carElem, 'Name', self.Name)
self.__addTag(carElem, 'UniqueId', self.UniqueId)
self.__addTag(carElem, 'Orientation', self.Orientation)
self.__addTag(carElem, 'Wells', self.Wells)
self.__addTag(carElem, 'Axles', self.Axles)
self.__addTag(carElem, 'Length', self.Length)
self.__addTag(carElem, 'IsEngine', self.IsEngine)
self.__addTag(carElem, 'IsGhost', self.IsGhost)
aTree.append(carElem)
return aTree
def getTag(self):
return self._element.tag
def __tagGrab(self, tagName, parent=self._element):
'''
Helper function for XML reading operations.
'''
return parent.find(tagName).text
def __addTag(self, element, tagName, textValue=None):
'''
Helper function for setting values for XML elements. Note that this
function assumes unique tag name values within element.
'''
element.append(Element(tagName))
if textValue:
element.find(tagName).text = str(textValue)
因此,如果我所有的方法都将 self 作为第一个参数,并且调用堆栈将问题指向类声明,但 self 没有被全局定义,那么我在这里做错了什么?
PS:如果有帮助的话,我正在使用最新的 IronPython 解释器,以防由于某种原因问题是 IronPython 特有的。
最佳答案
问题出在您的 __tagGrab
函数中:
def __tagGrab(self, tagName, parent=self._element):
您不能在 header 中使用 self
—— 而是使用 None
然后在正文中更正:
def __tagGrab(self, tagName, parent=None):
if parent is None:
parent = self._element
...
原因是在创建类对象时没有self
;除了 globals()
(它有 Element
加上一些其他项目),当 Python 到达 __tagGrab
时定义的唯一名称是 __module__
、__init__
、getTree
和 getTag
。
作为向自己证明这一点的实验,试试这个:
class TestClassCreation(object):
print("Started creating class")
print("names so far: %s" % vars())
def __init__(self):
pass
print("now we have %s" % vars())
def noop(self, default=None):
print("this gets run when noop is called")
print("and now have %s" % vars())
print()
print("and now we'll fail...")
def failure(self, some_arg=self.noop):
pass
print("we never get here...")
关于python - 如何解决未在 Python 中全局定义的 'self' 上的导入错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8069017/