Porter 词干过滤器
porter_stem
词元过滤器将单词还原为其基本(或词干)形式,并去除单词的常见后缀,这有助于通过词根匹配相似的单词。例如,单词 running
的词干是 run
。此词元过滤器主要用于英语,并提供基于 Porter 词干算法的词干提取功能。
示例
以下示例请求创建一个名为 my_stem_index
的新索引,并使用 porter_stem
过滤器配置一个分析器
PUT /my_stem_index
{
"settings": {
"analysis": {
"filter": {
"my_porter_stem": {
"type": "porter_stem"
}
},
"analyzer": {
"porter_analyzer": {
"tokenizer": "standard",
"filter": [
"lowercase",
"my_porter_stem"
]
}
}
}
}
}
生成的词元
使用以下请求检查使用该分析器生成的词元
POST /my_stem_index/_analyze
{
"text": "running runners ran",
"analyzer": "porter_analyzer"
}
响应包含生成的词元
{
"tokens": [
{
"token": "run",
"start_offset": 0,
"end_offset": 7,
"type": "<ALPHANUM>",
"position": 0
},
{
"token": "runner",
"start_offset": 8,
"end_offset": 15,
"type": "<ALPHANUM>",
"position": 1
},
{
"token": "ran",
"start_offset": 16,
"end_offset": 19,
"type": "<ALPHANUM>",
"position": 2
}
]
}