Link Search Menu Expand Document Documentation Menu

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
    }
  ]
}
剩余 350 字符

有问题?

想贡献?