NLTK 可用于停用词的语言

gal*_*007 9 python nlp nltk stop-words

我想知道在哪里可以找到 NLTK 停用词支持的语言(及其键)的完整列表。

我在https://pypi.org/project/stop-words/ 中找到了一个列表,但它不包含每个国家/地区的密钥。因此,您是否可以通过简单地检索列表尚不清楚stopwords.words("Bulgarian")。事实上,这会引发错误。

我查看了 NLTK 站点,有 4 个文档与“停用词”匹配,但没有一个文档描述了这一点。 https://www.nltk.org/search.html?q=stopwords&check_keywords=yes&area=default

他们的书中什么也没说:http ://www.nltk.org/book/ch02.html#stopwords_index_term

那么,你知道我在哪里可以找到钥匙列表吗?

Aks*_*kar 8

首先检查您是否已经下载了nltk软件包。
如果没有,您可以使用以下方式下载:

import nltk
nltk.download()
Run Code Online (Sandbox Code Playgroud)

之后,您可以在以下路径中找到停用词语言文件。

C:/Users/username/AppData/Roming/nltk_data/corpora/stopwords
Run Code Online (Sandbox Code Playgroud)

它支持 21 种语言(我nltk几天前安装的,所以这个数字必须是最新的)。您可以将文件名作为参数传递

nltk.corpus.stopwords.words('langauage')


小智 8

os.listdir('/root/nltk_data/corpora/stopwords/')

['hungarian',
 'swedish',
 'kazakh',
 'norwegian',
 'finnish',
 'arabic',
 'indonesian',
 'portuguese',
 'turkish',
 'azerbaijani',
 'slovene',
 'spanish',
 'danish',
 'nepali',
 'romanian',
 'greek',
 'dutch',
 'README',
 'tajik',
 'german',
 'english',
 'russian',
 'french',
 'italian']
Run Code Online (Sandbox Code Playgroud)

  • 否决:这种方法不跨平台,也不兼容环境。 (3认同)

小智 7

当您使用以下方法导入停用词时:

from nltk.corpus import stopwords
english_stopwords = stopwords.words(language)
Run Code Online (Sandbox Code Playgroud)

您正在根据文件 ID(语言)检索停用词。为了查看所有可用的停用词语言,您可以使用以下方法检索文件 ID 列表:

from nltk.corpus import stopwords
print(stopwords.fileids())
Run Code Online (Sandbox Code Playgroud)

在 nltk v3.4.5 的情况下,这将返回 23 种语言:

['arabic', 
 'azerbaijani', 
 'danish', 
 'dutch', 
 'english', 
 'finnish', 
 'french', 
 'german', 
 'greek',
 'hungarian', 
 'indonesian', 
 'italian', 
 'kazakh', 
 'nepali', 
 'norwegian', 
 'portuguese', 
 'romanian', 
 'russian', 
 'slovene', 
 'spanish', 
 'swedish', 
 'tajik', 
 'turkish']
Run Code Online (Sandbox Code Playgroud)