0

上位 20 件のオカレンスのリストを印刷すると、必要な実際のデータではなく、オブジェクトの場所だけが得られます。また、改善のためのアイデアがあれば、大歓迎です。助けてください。ありがとう。

これが私のコードです。

class topList():
    __slots__ = ( "name", "gender", "occurences" )

def mkList( name, gender, occurences ):
    find = topList()
    find.name = name
    find.gender = gender
    find.occurences = occurences
    return find

def main():
    year = input( 'Enter year: ' )
    file = open( 'yob' + year + '.txt' )
    lst = []
    femaleLst = []
    maleLst = []
    for line in file:
        line = line.strip().split( "," )
        names = mkList( line[0], line[1], line[2] )
        lst.append( names )
        if names.gender == 'F':
            femaleLst += [ line ]
        else:
            maleLst += [ line ]
    while len( lst ) < 20:
        male = maleLst.pop()
        female = femaleLst.pop()
        if maleLst.occurences > femaleLst.occurences:
            lst += [ male ]
        else:
            lst += [ female ]
    print( lst[ : 20] )

main()
4

1 に答える 1

2

メソッドをクラスに追加__repr____str__ます。

class topList():
    __slots__ = ( "name", "gender", "occurences" )

    def __repr__(self):
        return 'topList({s.name!r}, {s.gender!r}, {s.occurences!r})'.format(s=self)

    def __str__(self):
        return '{s.name} ({s.gender}): {s.occurences!r})'.format(s=self)

デモ:

>>> class topList():
...     __slots__ = ( "name", "gender", "occurences" )
...     def __str__(self):
...         return 'topList({s.name!r}, {s.gender!r}, {s.occurences!r})'.format(s=self)
... 
>>> tl = topList()
>>> tl.name = 'FooBar'
>>> tl.gender = 'm'
>>> tl.occurences = 42
>>> print(tl)
FooBar (m): 42
>>> tl
topList('FooBar', 'm', 42)

この__str__メソッドは、print()関数と同様に、オブジェクトが文字列に変換されると自動的に呼び出されます。

この__repr__メソッドは、repr()表現に使用され、オブジェクトがリストやその他のコンテナーに表示されるときに使用されます。

于 2013-10-12T19:20:02.513 に答える