谓词令牌过滤器
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
}
]
}