我知道如何在单个单词上执行SnowballStemmer(在我的情况下,在俄语单词上)。做下一件事:
from nltk.stem.snowball import SnowballStemmer
stemmer = SnowballStemmer("russian")
stemmer.stem("Василий")
'Васил'
如果我有一个像''Василий','Геннадий','Виталий''这样的单词列表,我该如何做?
我使用for循环的方法似乎不起作用:(
l=[stemmer.stem(word) for word in l]
答案 0 :(得分:5)
您的变量l
未预先定义,导致名称错误。请参阅我的最后两行进行修复。
>>> from nltk.stem.snowball import SnowballStemmer
>>> stemmer = SnowballStemmer("russian")
>>> my_words = ['Василий', 'Геннадий', 'Виталий']
>>> l=[stemmer.stem(word) for word in l]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'l' is not defined
>>> l=[stemmer.stem(word) for word in my_words]
>>> l
['васил', 'геннад', 'витал']