Simple pattern tokenizer

Simple pattern tokenizer

The simple_pattern tokenizer uses a regular expression to capture matching text as terms. The set of regular expression features it supports is more limited than the pattern tokenizer, but the tokenization is generally faster.

This tokenizer does not support splitting the input on a pattern match, unlike the pattern tokenizer. To split on pattern matches using the same restricted regular expression subset, see the simple_pattern_split tokenizer.

This tokenizer uses Lucene regular expressions. For an explanation of the supported features and syntax, see Regular Expression Syntax.

The default pattern is the empty string, which produces no terms. This tokenizer should always be configured with a non-default pattern.

Configuration

The simple_pattern tokenizer accepts the following parameters:

pattern

Lucene regular expression, defaults to the empty string.

Example configuration

This example configures the simple_pattern tokenizer to produce terms that are three-digit numbers

  1. resp = client.indices.create(
  2. index="my-index-000001",
  3. settings={
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "my_tokenizer"
  8. }
  9. },
  10. "tokenizer": {
  11. "my_tokenizer": {
  12. "type": "simple_pattern",
  13. "pattern": "[0123456789]{3}"
  14. }
  15. }
  16. }
  17. },
  18. )
  19. print(resp)
  20. resp1 = client.indices.analyze(
  21. index="my-index-000001",
  22. analyzer="my_analyzer",
  23. text="fd-786-335-514-x",
  24. )
  25. print(resp1)
  1. response = client.indices.create(
  2. index: 'my-index-000001',
  3. body: {
  4. settings: {
  5. analysis: {
  6. analyzer: {
  7. my_analyzer: {
  8. tokenizer: 'my_tokenizer'
  9. }
  10. },
  11. tokenizer: {
  12. my_tokenizer: {
  13. type: 'simple_pattern',
  14. pattern: '[0123456789]{3}'
  15. }
  16. }
  17. }
  18. }
  19. }
  20. )
  21. puts response
  22. response = client.indices.analyze(
  23. index: 'my-index-000001',
  24. body: {
  25. analyzer: 'my_analyzer',
  26. text: 'fd-786-335-514-x'
  27. }
  28. )
  29. puts response
  1. const response = await client.indices.create({
  2. index: "my-index-000001",
  3. settings: {
  4. analysis: {
  5. analyzer: {
  6. my_analyzer: {
  7. tokenizer: "my_tokenizer",
  8. },
  9. },
  10. tokenizer: {
  11. my_tokenizer: {
  12. type: "simple_pattern",
  13. pattern: "[0123456789]{3}",
  14. },
  15. },
  16. },
  17. },
  18. });
  19. console.log(response);
  20. const response1 = await client.indices.analyze({
  21. index: "my-index-000001",
  22. analyzer: "my_analyzer",
  23. text: "fd-786-335-514-x",
  24. });
  25. console.log(response1);
  1. PUT my-index-000001
  2. {
  3. "settings": {
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "my_tokenizer"
  8. }
  9. },
  10. "tokenizer": {
  11. "my_tokenizer": {
  12. "type": "simple_pattern",
  13. "pattern": "[0123456789]{3}"
  14. }
  15. }
  16. }
  17. }
  18. }
  19. POST my-index-000001/_analyze
  20. {
  21. "analyzer": "my_analyzer",
  22. "text": "fd-786-335-514-x"
  23. }

The above example produces these terms:

  1. [ 786, 335, 514 ]