Switching Between Simplified and Traditional Chinese for Data Search in an Elasticsearch Cluster
This topic describes how to switch between simplified and traditional Chinese for data search in an Elasticsearch cluster.
Scenario
The simplified-traditional Chinese conversion plugin converts between simplified and traditional Chinese. With this plugin, you can search index data containing the corresponding simplified Chinese based on the traditional Chinese keyword, and vice versa.
This plugin is installed by default. You do not need to install it by yourself.
The simplified-traditional Chinese conversion plugin can be used as the analyzer, tokenizer, token-filter, or char-filter.
The simplified-traditional Chinese conversion plugin provides the following two conversion types:
- s2t: converts simplified Chinese to traditional Chinese.
- t2s: converts traditional Chinese to simplified Chinese.
Switching Between Simplified and Traditional Chinese for Data Search
- Log in to Kibana.
- Log in to the CSS management console.
- In the navigation pane on the left, choose Clusters > Elasticsearch.
- In the cluster list, find the target cluster, and click Kibana in the Operation column to log in to the Kibana console.
- In the left navigation pane, choose Dev Tools.
- Run the following command to create the stconvert index and specify the user-defined mapping to define the data type:
Sample code for Elasticsearch clusters earlier than 7.x:
PUT /stconvert { "settings": { "number_of_shards": 1, "number_of_replicas": 0, "analysis": { "analyzer": { "ts_ik": { "tokenizer": "ik_smart", "char_filter": [ "tsconvert", "stconvert" ] } }, "char_filter": { "tsconvert": { "type": "stconvert", "convert_type": "t2s" }, "stconvert": { "type": "stconvert", "convert_type": "s2t" } } } }, "mappings": { "type": { "properties": { "desc": { "type": "text", "analyzer": "ts_ik" } } } } }
Sample code for Elasticsearch 7.x or later:
PUT /stconvert { "settings": { "number_of_shards": 1, "number_of_replicas": 0, "analysis": { "analyzer": { "ts_ik": { "tokenizer": "ik_smart", "char_filter": [ "tsconvert", "stconvert" ] } }, "char_filter": { "tsconvert": { "type": "stconvert", "convert_type": "t2s" }, "stconvert": { "type": "stconvert", "convert_type": "s2t" } } } }, "mappings": { "properties": { "desc": { "type": "text", "analyzer": "ts_ik" } } } }
The command output is similar to the following:
{ "acknowledged" : true, "shards_acknowledged" : true, "index" : "stconvert" }
- Run the following command to import data to index stconvert:
Sample code for Elasticsearch clusters earlier than 7.x:
POST /stconvert/type/1 { "desc": "Text in traditional Chinese" }
Sample code for Elasticsearch 7.x or later:
POST /stconvert/_doc/1 { "desc": "Text in traditional Chinese" }
If the value of failed in the command output is 0, the data is imported successfully.
- Run the following command to search for the keyword and check the search result:
GET /stconvert/_search { "query": { "match": { "desc": "Keyword" } } }
The command output is similar to the following:
{ "took" : 15, "timed_out" : false, "_shards" : { "total" : 1, "successful" : 1, "skipped" : 0, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.5753642, "hits" : [ { "_index" : "stconvert", "_type" : "type", "_id" : "1", "_score" : 0.5753642, "_source" : { "desc": "Text in traditional Chinese" } } ] } }
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot