Пользовательский анализатор Elasticsearch

Можно ли создать собственный анализатор elasticsearch, который может разделить индекс по пространству, а затем создать два токена? Во-первых, со всем до космоса, а во-вторых, со всем. Например: я сохранил запись с полем, которое имеет следующий текст: «35 G». Теперь я хочу получить эту запись, введя в это поле только запрос «35» или «35 G». Таким образом, эластичный должен создать два токена: ['35', '35 G'] и не более.

Если это возможно, как этого добиться?

0
0
59
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Выполнимо с помощью path_hierarchy токенизатор.

PUT test
{
  "settings": {
    "analysis": {
      "analyzer": {
        "my_analyzer": {
          "tokenizer": "my_tokenizer"
        }
      },
      "tokenizer": {
        "my_tokenizer": {
          "type": "path_hierarchy",
          "delimiter": " "
        }
      }
    }
  }
  ...
}

И сейчас

POST test/_analyze
{
  "analyzer": "my_analyzer",
  "text": "35 G"
}

выходы

{
  "tokens": [
    {
      "token": "35",
      "start_offset": 0,
      "end_offset": 2,
      "type": "word",
      "position": 0
    },
    {
      "token": "35 G",
      "start_offset": 0,
      "end_offset": 4,
      "type": "word",
      "position": 0
    }
  ]
}

Другие вопросы по теме