Python 从字典中检索类对象

Python 从字典中检索类对象,python,dictionary,Python,Dictionary,作为初级大学Python项目的一部分,我目前正在创建一个单词数据库,可以是名词、动词、限定词、形容词 现在我遇到的问题是,通过lexicon.readfromfile方法读入程序的单词是通过一个类的实例(无论是名词、动词还是形容词)放入字典的。这就产生了一个问题,我完全不知道如何从字典中调用这些对象,因为它们没有作为键的变量,而是内存位置,请参见以下内容: {<__main__.Verb object at 0x02F4F110>, <__main__.Noun object

作为初级大学Python项目的一部分,我目前正在创建一个单词数据库,可以是名词、动词、限定词、形容词

现在我遇到的问题是,通过lexicon.readfromfile方法读入程序的单词是通过一个类的实例(无论是名词、动词还是形容词)放入字典的。这就产生了一个问题,我完全不知道如何从字典中调用这些对象,因为它们没有作为键的变量,而是内存位置,请参见以下内容:

{<__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