如何从迭代中获取输出,将其存储在字典中



所以我有这个脚本(运行Python 3.5)使用Google API和Newspaper。 它在谷歌上搜索与睡眠有关的文章。然后使用报纸,我遍历这些URL。我要求报纸做的只是返回该文章的关键字列表,我通过写article.keywords来调用它。

for url in google.search('sleep', num=2, stop=1):
    article = Article(url)      
    article.download() 
    article.parse()
    article.nlp()     
    print(article.keywords)

返回的关键字(针对给定文章)如下所示:

['education', 'nights', 'start', 'pill', 'supplement', 'research', 'national', 'sleep', 'sleeping', 'trouble', 'using', 'taking']

但是我想创建一个字典,其中包含所有结果的所有关键字:也就是说,正在迭代的每篇文章的关键字。我该怎么做?

假设字典键应该是文章 url:

keywords = {}
for url in google.search('sleep', num=2, stop=1):
    article = Article(url)      
    article.download() 
    article.parse()
    article.nlp()  
    keywords[url] = article.keywords
print(keywords)

或者,如果您想获得所有文章中所有关键字的列表:

keywords = []
for url in google.search('sleep', num=2, stop=1):
    article = Article(url)      
    article.download() 
    article.parse()
    article.nlp()  
    keywords += article.keywords
print(keywords)

防止多次插入关键字(几乎与另一个答案相同)

keywords = []
for url in google.search('sleep', num=2, stop=1):
  article = Article(url)      
  article.download() 
  article.parse()
  article.nlp()
  for kw in article.keywords:
    if kw not in keywords:
      keywords.append( kw )

或者更好的是,使用 set 而不是 list .

相关内容

  • 没有找到相关文章

最新更新