Mapping Character Filter

原文链接 : https://www.elastic.co/guide/en/elasticsearch/reference/5.3/analysis-mapping-charfilter.html

译文链接 :http://www.apache.wiki/display/Elasticsearch/Mapping+Character+Filter

贡献者 : 谢雄ApacheCNApache中文网

Mapping Character Filter 接收键和值映射作为配置参数,每当在预处理过程中遇到与键值映射中的键相同的字符串时,就会使用该键对应的值去替换它。

原始文本中的字符串和键值映射中的键的匹配是贪心的,在对给定的文本进行预处理过程中如果配置的键值映射存在包含关系,会优先匹配最长键。可以用空字符串进行替换。

配置

参数名称 参数说明
mappings 一组映射,每个元素的格式为key => value。
mappings_path 一个相对或者绝对的文件路径,指向一个每行包含一个 key =>value 映射的UTF-8编码文本映射文件。

以上两个参数必须提供一个。

在下面的例子中,我们将使用Mapping Character Filter来实现用拉丁语数字和阿拉伯数字的等价替换:

案例

  1. PUT my_index
  2. {
  3. "settings": {
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "keyword",
  8. "char_filter": [
  9. "my_char_filter"
  10. ]
  11. }
  12. },
  13. "char_filter": {
  14. "my_char_filter": {
  15. "type": "mapping",
  16. "mappings": [
  17. "٠ => 0",
  18. "١ => 1",
  19. "٢ => 2",
  20. "٣ => 3",
  21. "٤ => 4",
  22. "٥ => 5",
  23. "٦ => 6",
  24. "٧ => 7",
  25. "٨ => 8",
  26. "٩ => 9"
  27. ]
  28. }
  29. }
  30. }
  31. }
  32. }
  33. POST my_index/_analyze
  34. {
  35. "analyzer": "my_analyzer",
  36. "text": "My license plate is ٢٥٠١٥"
  37. }

上面的案例将会返回如下结果:

  1. [ My license plate is 25015 ]

键和值都可以是具有多个字符的字符串。 以下示例用指定的文本替换 :) 和 :( 表情符号:

案例

  1. PUT my_index
  2. {
  3. "settings": {
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "standard",
  8. "char_filter": [
  9. "my_char_filter"
  10. ]
  11. }
  12. },
  13. "char_filter": {
  14. "my_char_filter": {
  15. "type": "mapping",
  16. "mappings": [
  17. ":) => _happy_",
  18. ":( => _sad_"
  19. ]
  20. }
  21. }
  22. }
  23. }
  24. }
  25. POST my_index/_analyze
  26. {
  27. "analyzer": "my_analyzer",
  28. "text": "I'm delighted about it :("
  29. }

上面的案例将会返回如下结果:

  1. [ I'm, delighted, about, it, _sad_ ]