Python 从字典中检索类对象
作为初级大学Python项目的一部分,我目前正在创建一个单词数据库,可以是名词、动词、限定词、形容词 现在我遇到的问题是,通过lexicon.readfromfile方法读入程序的单词是通过一个类的实例(无论是名词、动词还是形容词)放入字典的。这就产生了一个问题,我完全不知道如何从字典中调用这些对象,因为它们没有作为键的变量,而是内存位置,请参见以下内容:Python 从字典中检索类对象,python,dictionary,Python,Dictionary,作为初级大学Python项目的一部分,我目前正在创建一个单词数据库,可以是名词、动词、限定词、形容词 现在我遇到的问题是,通过lexicon.readfromfile方法读入程序的单词是通过一个类的实例(无论是名词、动词还是形容词)放入字典的。这就产生了一个问题,我完全不知道如何从字典中调用这些对象,因为它们没有作为键的变量,而是内存位置,请参见以下内容: {<__main__.Verb object at 0x02F4F110>, <__main__.Noun object
{<__main__.Verb object at 0x02F4F110>, <__main__.Noun object at 0x02F4F130>, <__main__.Adjective object at 0x02F4F1D0>, <__main__.Noun object at 0x02F4F170>}
你那儿有一套,没有字典。集合可以让您快速轻松地检查给定实例是否在集合中,但是,正如您所发现的,除非您已经知道它是什么,否则无法轻松地获取特定值。没关系,因为这不是布景的目的
对于字典,在将键添加到字典时将其与值关联。然后使用键将值取回来。因此,制作一个字典而不是一个集合,并使用有意义的键,这样您就可以轻松地获取值
或者,因为我看到您在将其转换为集合之前已经在制作列表,所以只需返回该列表即可;您可以通过索引轻松访问列表中的项目。换句话说,一开始不要制造问题,你就不会有问题。Related:。而且,这似乎是一个集合,而不是一个命令。
class Lexicon(object):
'A container clas for word objects'
def __init__(self):
self.words = {}
def addword(self, word):
self.words[word.stringrep] = word
def removeword(self, word):
if word in self.words:
del(word)
print('Word has been deleted from the Lexicon' )
else:
print('That word is not in the Lexicon')
def getword(self,wordstring):
if wordstring in self.words:
return self.words[wordstring]
else:
return None
def containsword(self,string):
if string in self.words:
return True
else:
return False
def getallwords(self):
allwordslist = []
for w in self.words:
allwordslist.append(self.words[w])
return set(allwordslist)
def readfromfile(self, x):
filehandle = open(x, 'r')
while True:
line = filehandle.readline()
if line == '':
break
line = line.strip()
info = line.split(',')
if info[1] == 'CN' or info[1] == 'PN':
noun=Noun(info[0],info[1])
noun.setattribute('regular',bool(info[2]))
self.addword(noun)
elif info[1] == 'A':
adjective=Adjective(info[0],info[1])
adjective.setattribute('comparative', bool(info[2]))
self.addword(adjective)
elif info[1] == 'V':
verb=Verb(info[0],info[1])
verb.setattribute('transitive', bool(info[2]))
verb.setattribute('past', info[3])
self.addword(verb)
def writetofile(self, x):
filehandle = open(x, 'w')
for t in self.words.values():
filehandle.write(t.getFormattedString() + '\n')
filehandle.close()
#---------------------------------------------------------------------------#
class Word(object):
'A word of any category'
def __init__(self,stringrep,category):
self.wordattribute = {}
self.stringrep = stringrep
self.category = category
def setattribute(self, attributename, attributevalue):
self.wordattribute[attributename] = attributevalue
def getvalue(self,name):
if name in self.wordattribute:
return self.wordattribute[name]
else:
return none
def __str__(self):
return self.stringrep + ':' + self.category
def __lt__(self,otherword):
return self.stringrep < otherword.stringrep
class Verb(Word):
'"Represents a Verb."'
def __init__(self, stringrep, category):
super().__init__(stringrep,category)
def istransitive(self):
return self.transitive
def getFormattedString(self):
n = '{stringrep},{category}'
n = n.format(stringrep=self.stringrep, category=self.category)
for i in range(1,2):
for v,b in self.wordattribute.items():
n = n+','+str(b)
return n