Elasticsearch搜索具有“#”字符的单词

时间:2013-07-08 12:34:40

标签: elasticsearch

例如,我现在正在这样搜索:

http://localhost:9200/posts/post/_search?q=content:%23sachin

但是,我得到了'sachin'而不是'#sachin'的所有结果。另外,我正在写一个正则表达式来获取术语数。方面看起来像这样:

"facets": {
  "content": {
      "terms": {
        "field": "content",
        "size": 1000,
        "all_terms": false,
        "regex": "#sachin",
        "regex_flags": [
          "DOTALL",
          "CASE_INSENSITIVE"
        ]
      }
    }
}

这不会返回任何值。我认为这与在正则表达式中转义'#'有关,但我不知道该怎么做。我试图逃避它\\\,但它没有用。在这方面有谁能帮助我?

2 个答案:

答案 0 :(得分:6)

本文提供了有关如何使用自定义分析器保存#和@的信息: https://web.archive.org/web/20160304014858/http://www.fullscale.co/blog/2013/03/04/preserving_specific_characters_during_tokenizing_in_elasticsearch.html

curl -XPUT 'http://localhost:9200/twitter' -d '{
    "settings" : {
        "index" : {
            "number_of_shards" : 1,
            "number_of_replicas" : 1
        },  
        "analysis" : {
            "filter" : {
                "tweet_filter" : {
                    "type" : "word_delimiter",
                    "type_table": ["# => ALPHA", "@ => ALPHA"]
                }   
            },
            "analyzer" : {
                "tweet_analyzer" : {
                    "type" : "custom",
                    "tokenizer" : "whitespace",
                    "filter" : ["lowercase", "tweet_filter"]
                }
            }
        }
    },
    "mappings" : {
        "tweet" : {
            "properties" : {
                "msg" : {
                    "type" : "string",
                    "analyzer" : "tweet_analyzer"
                }
            }
        }
    }
}'

这不涉及方面,但重新定义分析器中这些特殊字符的类型可能有所帮助。

答案 1 :(得分:0)

值得考虑的另一种方法是索引一个特殊的(例如"保留")字而不是哈希符号。例如:HASHSYMBOLCHAR。确保您将替换#'#'查询中的字符也是如此。