Link Search Menu Expand Document Documentation Menu

谓词令牌过滤器

predicate_token_filter 根据自定义脚本中定义的条件评估是否保留或丢弃令牌。令牌在分析谓词上下文中进行评估。此过滤器仅支持内联 Painless 脚本。

参数

predicate_token_filter 有一个必填参数:script。此参数提供一个用于评估是否应保留令牌的条件。

示例

以下示例请求创建一个名为 predicate_index 的新索引,并配置一个带有 predicate_token_filter 的分析器。该过滤器指定只输出长度大于 7 个字符的令牌。

PUT /predicate_index
{
  "settings": {
    "analysis": {
      "filter": {
        "my_predicate_filter": {
          "type": "predicate_token_filter",
          "script": {
            "source": "token.term.length() > 7"
          }
        }
      },
      "analyzer": {
        "predicate_analyzer": {
          "tokenizer": "standard",
          "filter": [
            "lowercase",
            "my_predicate_filter"
          ]
        }
      }
    }
  }
}

生成的词元

使用以下请求检查使用该分析器生成的词元

POST /predicate_index/_analyze
{
  "text": "The OpenSearch community is growing rapidly",
  "analyzer": "predicate_analyzer"
}

响应包含生成的词元

{
  "tokens": [
    {
      "token": "opensearch",
      "start_offset": 4,
      "end_offset": 14,
      "type": "<ALPHANUM>",
      "position": 1
    },
    {
      "token": "community",
      "start_offset": 15,
      "end_offset": 24,
      "type": "<ALPHANUM>",
      "position": 2
    }
  ]
}
剩余 350 字符

有问题?

想做贡献?