From 630f33d4e8dae6357b2f44b36c707579c232b2b5 Mon Sep 17 00:00:00 2001 From: Anton Rubin Date: Fri, 13 Sep 2024 14:58:52 +0100 Subject: [PATCH 1/4] adding pattern_capture token filter docs #8240 Signed-off-by: Anton Rubin --- _analyzers/token-filters/index.md | 2 +- _analyzers/token-filters/pattern-capture.md | 95 +++++++++++++++++++++ 2 files changed, 96 insertions(+), 1 deletion(-) create mode 100644 _analyzers/token-filters/pattern-capture.md diff --git a/_analyzers/token-filters/index.md b/_analyzers/token-filters/index.md index a9b621d5ab..8c00defc47 100644 --- a/_analyzers/token-filters/index.md +++ b/_analyzers/token-filters/index.md @@ -43,7 +43,7 @@ Token filter | Underlying Lucene token filter| Description `multiplexer` | N/A | Emits multiple tokens at the same position. Runs each token through each of the specified filter lists separately and outputs the results as separate tokens. `ngram` | [NGramTokenFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/ngram/NGramTokenFilter.html) | Tokenizes the given token into n-grams of lengths between `min_gram` and `max_gram`. Normalization | `arabic_normalization`: [ArabicNormalizer](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/ar/ArabicNormalizer.html)
`german_normalization`: [GermanNormalizationFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/de/GermanNormalizationFilter.html)
`hindi_normalization`: [HindiNormalizer](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/hi/HindiNormalizer.html)
`indic_normalization`: [IndicNormalizer](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/in/IndicNormalizer.html)
`sorani_normalization`: [SoraniNormalizer](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/ckb/SoraniNormalizer.html)
`persian_normalization`: [PersianNormalizer](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/fa/PersianNormalizer.html)
`scandinavian_normalization` : [ScandinavianNormalizationFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/miscellaneous/ScandinavianNormalizationFilter.html)
`scandinavian_folding`: [ScandinavianFoldingFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/miscellaneous/ScandinavianFoldingFilter.html)
`serbian_normalization`: [SerbianNormalizationFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/sr/SerbianNormalizationFilter.html) | Normalizes the characters of one of the listed languages. -`pattern_capture` | N/A | Generates a token for every capture group in the provided regular expression. Uses [Java regular expression syntax](https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html). +[`pattern_capture`]({{site.url}}{{site.baseurl}}/analyzers/token-filters/pattern-capture/) | N/A | Generates a token for every capture group in the provided regular expression. Uses [Java regular expression syntax](https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html). `pattern_replace` | N/A | Matches a pattern in the provided regular expression and replaces matching substrings. Uses [Java regular expression syntax](https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html). `phonetic` | N/A | Uses a phonetic encoder to emit a metaphone token for each token in the token stream. Requires installing the `analysis-phonetic` plugin. `porter_stem` | [PorterStemFilter](https://lucene.apache.org/core/9_10_0/analysis/common/org/apache/lucene/analysis/en/PorterStemFilter.html) | Uses the [Porter stemming algorithm](https://tartarus.org/martin/PorterStemmer/) to perform algorithmic stemming for the English language. diff --git a/_analyzers/token-filters/pattern-capture.md b/_analyzers/token-filters/pattern-capture.md new file mode 100644 index 0000000000..94822663b0 --- /dev/null +++ b/_analyzers/token-filters/pattern-capture.md @@ -0,0 +1,95 @@ +--- +layout: default +title: Pattern capture +parent: Token filters +nav_order: 310 +--- + +# Pattern capture token filter + +The `pattern_capture` token filter a powerful filter that uses regular expressions to capture and extract parts of text according to specific patterns. This filter can be useful when you want to extract particular parts of tokens, such as email domains, hashtags, or numbers, and reuse them for further analysis or indexing. + +## Parameters + +The `pattern_capture` token filter can be configured with the following parameters: + +- `patterns`: An array of regular expressions used to capture parts of the text. (Array of strings, _Required_) +- `preserve_original`: Retain original token in the output. Default is `true`. (Boolean, _Optional_) + + +## Example + +The following example request creates a new index named `email_index` and configures an analyzer with `pattern_capture` filter to extract the local part and domain from email address: + +```json +PUT /email_index +{ + "settings": { + "analysis": { + "filter": { + "email_pattern_capture": { + "type": "pattern_capture", + "preserve_original": true, + "patterns": [ + "^([^@]+)", + "@(.+)$" + ] + } + }, + "analyzer": { + "email_analyzer": { + "tokenizer": "uax_url_email", + "filter": [ + "email_pattern_capture", + "lowercase" + ] + } + } + } + } +} +``` +{% include copy-curl.html %} + +## Generated tokens + +Use the following request to examine the tokens generated using the analyzer: + +```json +POST /email_index/_analyze +{ + "text": "john.doe@example.com", + "analyzer": "email_analyzer" +} +``` +{% include copy-curl.html %} + +The response contains the generated tokens: + +```json +{ + "tokens": [ + { + "token": "john.doe@example.com", + "start_offset": 0, + "end_offset": 20, + "type": "", + "position": 0 + }, + { + "token": "john.doe", + "start_offset": 0, + "end_offset": 20, + "type": "", + "position": 0 + }, + { + "token": "example.com", + "start_offset": 0, + "end_offset": 20, + "type": "", + "position": 0 + } + ] +} +``` From fe9df5070c8d75aef1e438ecd13cdc4fc0175018 Mon Sep 17 00:00:00 2001 From: Anton Rubin Date: Wed, 16 Oct 2024 18:28:33 +0100 Subject: [PATCH 2/4] updating parameter table Signed-off-by: Anton Rubin --- _analyzers/token-filters/pattern-capture.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/_analyzers/token-filters/pattern-capture.md b/_analyzers/token-filters/pattern-capture.md index 94822663b0..8a7bdd4b07 100644 --- a/_analyzers/token-filters/pattern-capture.md +++ b/_analyzers/token-filters/pattern-capture.md @@ -11,10 +11,12 @@ The `pattern_capture` token filter a powerful filter that uses regular expressio ## Parameters -The `pattern_capture` token filter can be configured with the following parameters: +The `pattern_capture` token filter can be configured with the following parameters. -- `patterns`: An array of regular expressions used to capture parts of the text. (Array of strings, _Required_) -- `preserve_original`: Retain original token in the output. Default is `true`. (Boolean, _Optional_) +Parameter | Required/Optional | Data type | Description +:--- | :--- | :--- | :--- +`patterns` | Required | Array of strings | An array of regular expressions used to capture parts of the text. +`preserve_original` | Required | Boolean| Retain original token in the output. Default is `true`. ## Example From 46045f017d93a2a8b8ae9ee9fe634e499e2d3090 Mon Sep 17 00:00:00 2001 From: Fanit Kolchina Date: Fri, 15 Nov 2024 16:20:53 -0500 Subject: [PATCH 3/4] Doc review Signed-off-by: Fanit Kolchina --- _analyzers/token-filters/pattern-capture.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/_analyzers/token-filters/pattern-capture.md b/_analyzers/token-filters/pattern-capture.md index 8a7bdd4b07..7b62c1a68f 100644 --- a/_analyzers/token-filters/pattern-capture.md +++ b/_analyzers/token-filters/pattern-capture.md @@ -7,7 +7,7 @@ nav_order: 310 # Pattern capture token filter -The `pattern_capture` token filter a powerful filter that uses regular expressions to capture and extract parts of text according to specific patterns. This filter can be useful when you want to extract particular parts of tokens, such as email domains, hashtags, or numbers, and reuse them for further analysis or indexing. +The `pattern_capture` token filter is a powerful filter that uses regular expressions to capture and extract parts of text according to specific patterns. This filter can be useful when you want to extract particular parts of tokens, such as email domains, hashtags, or numbers, and reuse them for further analysis or indexing. ## Parameters @@ -16,12 +16,12 @@ The `pattern_capture` token filter can be configured with the following paramete Parameter | Required/Optional | Data type | Description :--- | :--- | :--- | :--- `patterns` | Required | Array of strings | An array of regular expressions used to capture parts of the text. -`preserve_original` | Required | Boolean| Retain original token in the output. Default is `true`. +`preserve_original` | Required | Boolean| Whether to keep the original token in the output. Default is `true`. ## Example -The following example request creates a new index named `email_index` and configures an analyzer with `pattern_capture` filter to extract the local part and domain from email address: +The following example request creates a new index named `email_index` and configures an analyzer with a `pattern_capture` filter to extract the local part and domain name from an email address: ```json PUT /email_index From 1e8debebe815a5dd26c2b134e7c59a4571097434 Mon Sep 17 00:00:00 2001 From: kolchfa-aws <105444904+kolchfa-aws@users.noreply.github.com> Date: Mon, 25 Nov 2024 14:02:03 -0500 Subject: [PATCH 4/4] Apply suggestions from code review Co-authored-by: Nathan Bower Signed-off-by: kolchfa-aws <105444904+kolchfa-aws@users.noreply.github.com> --- _analyzers/token-filters/pattern-capture.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_analyzers/token-filters/pattern-capture.md b/_analyzers/token-filters/pattern-capture.md index 7b62c1a68f..cff36b583d 100644 --- a/_analyzers/token-filters/pattern-capture.md +++ b/_analyzers/token-filters/pattern-capture.md @@ -15,7 +15,7 @@ The `pattern_capture` token filter can be configured with the following paramete Parameter | Required/Optional | Data type | Description :--- | :--- | :--- | :--- -`patterns` | Required | Array of strings | An array of regular expressions used to capture parts of the text. +`patterns` | Required | Array of strings | An array of regular expressions used to capture parts of text. `preserve_original` | Required | Boolean| Whether to keep the original token in the output. Default is `true`.