我试图将< 2000的图书名称复制到新列表中。但我遇到的问题是它只复制了#1984;"并且它将它作为单个字符复制到列表中,而不是复制它应该的所有名称
from collections import namedtuple
Book = namedtuple('Book','author title genre year price instock')
BSI = [ Book('John Green', 'Paper Towns', 'Young Adult', 2008, 7.00, 200),
Book('Beverly Clearly', 'Ramona Forever', 'Children', 1924, 9.00, 150),
Book('Vladmir Nabokov', 'Lolita', 'Tragicomedy', 1958, 15.00 , 80),
Book('J.D. Salinger', 'Catcher in the Rye', 'Young Adult', 1951, 10.00, 130),
Book('George Orwell', '1984', 'Dystopia', 1949, 7.00, 300),
Book('Jeannette Walls','The Glass Castle','Memoir', 2006, 15.00 , 100)]
older_books = []
for books in BSI:
if (books.year<2000):
older_books=list(books.title)
print(older_books) #Outputs ['1', '9', '8', '4']
应该输出什么
Ramona Forever
洛丽塔
守望者在黑麦中 1984
答案 0 :(得分:3)
对于每个for
循环,代码将覆盖列表older_books
和最后一本书名称(转换为列表),因为您没有附加到它,而只是每次都创建一个新列表。
>>> list('Ramona Forever')
['R', 'a', 'm', 'o', 'n', 'a', ' ', 'F', 'o', 'r', 'e', 'v', 'e', 'r']
>>> list('1984')
['1', '9', '8', '4']
使用list.append
,以便所有符合条件的书名都会附加到单个列表中:
>>> older_books = []
>>> older_books.append('Ramona Forever')
>>> older_books.append('1984')
>>> older_books
['Ramona Forever', '1984']
for books in BSI:
if books.year < 2000:
older_books.append(books.title) # <---
更新使用list comprehension的替代方案:
older_books = [b.title for b in BSI if b.year < 2000]