所以我有这个脚本(运行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
.