查询自定义词库状态
功能介绍
云搜索服务的词库用于对文本进行分词,使得一些特殊词语在分词的时候能够被识别 出来,便于根据关键词搜索文本数据。例如,根据公司名称来查询,如“华为”;或者根据网络流行词来查询,如“喜大普奔”。也支持基于同义词词库,根据同义词搜 索文本数据。CSS服务使用的分词器包括IK分词器和同义词分词器。IK分词器配备主词词库和停词词库;同义词分词器配备同义词词库。其中,IK分词器包含ik_max_word和ik_smart分词 策略。同义词分词器使用的是ik_synonym分词策略。该接口用于查询自定义词库的加载状态。
调用方法
请参见如何调用API。
URI
GET /v1.0/{project_id}/clusters/{cluster_id}/thesaurus
请求参数
无
响应参数
状态码:200
参数 |
参数类型 |
描述 |
---|---|---|
status |
String |
参数解释: 自定义词库加载状态。 取值范围:
|
bucket |
String |
参数解释: 最近一次更新存放词库文件的OBS桶。 取值范围: 不涉及 |
mainObj |
String |
参数解释: 主词词库文件对象。 取值范围: 不涉及 |
stopObj |
String |
参数解释: 停词词库文件对象。 取值范围: 不涉及 |
synonymObj |
String |
参数解释: 同义词词库文件对象。 取值范围: 不涉及 |
staticMainObj |
String |
参数解释: 静态主词词库文件对象。 取值范围: 不涉及 |
staticStopObj |
String |
参数解释: 静态主词词库文件对象。 取值范围: 不涉及 |
extraMainObj |
String |
参数解释: Extra主词词库库文件对象。 取值范围: 不涉及 |
extraStopObj |
String |
参数解释: Extra停词词库对象。 取值范围: 不涉及 |
updateTime |
String |
参数解释: 词库最近更新时间。 取值范围: 不涉及 |
updateDetails |
String |
参数解释: 词库更新详情。 取值范围: 不涉及 |
clusterId |
String |
参数解释: 指定配置自定义词库的集群ID。 取值范围: 不涉及 |
id |
String |
参数解释: 词库的ID。 取值范围: 不涉及 |
请求示例
查询自定义词库的加载状态。
GET https://{Endpoint}/v1.0/{project_id}/clusters/ea244205-d641-45d9-9dcb-ab2236bcd07e/thesaurus
响应示例
状态码:200
请求已成功。
{ "status" : "Loaded", "operateStatus" : "success", "id" : "e766bd5a-79b0-4d1a-8402-fdeb017a36d1", "bucket" : "test-bucket", "mainObj" : "word/main.txt", "stopObj" : "word/stop.txt", "synonymObj" : "word/synonym.txt", "staticMainObj" : "Unused", "staticStopObj" : "Unused", "extraMainObj" : "Unused", "extraStopObj" : "Unused", "updateTime" : 1521184757000, "updateDetails" : "allinstancesareloadedsuccessfully.", "clusterId" : "ea244205-d641-45d9-9dcb-ab2236bcd07e" }
SDK代码示例
SDK代码示例如下。
Java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
package com.huaweicloud.sdk.test; import com.huaweicloud.sdk.core.auth.ICredential; import com.huaweicloud.sdk.core.auth.BasicCredentials; import com.huaweicloud.sdk.core.exception.ConnectionException; import com.huaweicloud.sdk.core.exception.RequestTimeoutException; import com.huaweicloud.sdk.core.exception.ServiceResponseException; import com.huaweicloud.sdk.css.v1.region.CssRegion; import com.huaweicloud.sdk.css.v1.*; import com.huaweicloud.sdk.css.v1.model.*; public class ShowIkThesaurusSolution { public static void main(String[] args) { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment String ak = System.getenv("CLOUD_SDK_AK"); String sk = System.getenv("CLOUD_SDK_SK"); String projectId = "{project_id}"; ICredential auth = new BasicCredentials() .withProjectId(projectId) .withAk(ak) .withSk(sk); CssClient client = CssClient.newBuilder() .withCredential(auth) .withRegion(CssRegion.valueOf("<YOUR REGION>")) .build(); ShowIkThesaurusRequest request = new ShowIkThesaurusRequest(); request.withClusterId("{cluster_id}"); try { ShowIkThesaurusResponse response = client.showIkThesaurus(request); System.out.println(response.toString()); } catch (ConnectionException e) { e.printStackTrace(); } catch (RequestTimeoutException e) { e.printStackTrace(); } catch (ServiceResponseException e) { e.printStackTrace(); System.out.println(e.getHttpStatusCode()); System.out.println(e.getRequestId()); System.out.println(e.getErrorCode()); System.out.println(e.getErrorMsg()); } } } |
Python
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# coding: utf-8 import os from huaweicloudsdkcore.auth.credentials import BasicCredentials from huaweicloudsdkcss.v1.region.css_region import CssRegion from huaweicloudsdkcore.exceptions import exceptions from huaweicloudsdkcss.v1 import * if __name__ == "__main__": # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak = os.environ["CLOUD_SDK_AK"] sk = os.environ["CLOUD_SDK_SK"] projectId = "{project_id}" credentials = BasicCredentials(ak, sk, projectId) client = CssClient.new_builder() \ .with_credentials(credentials) \ .with_region(CssRegion.value_of("<YOUR REGION>")) \ .build() try: request = ShowIkThesaurusRequest() request.cluster_id = "{cluster_id}" response = client.show_ik_thesaurus(request) print(response) except exceptions.ClientRequestException as e: print(e.status_code) print(e.request_id) print(e.error_code) print(e.error_msg) |
Go
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
package main import ( "fmt" "github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic" css "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/css/v1" "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/css/v1/model" region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/css/v1/region" ) func main() { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK") projectId := "{project_id}" auth := basic.NewCredentialsBuilder(). WithAk(ak). WithSk(sk). WithProjectId(projectId). Build() client := css.NewCssClient( css.CssClientBuilder(). WithRegion(region.ValueOf("<YOUR REGION>")). WithCredential(auth). Build()) request := &model.ShowIkThesaurusRequest{} request.ClusterId = "{cluster_id}" response, err := client.ShowIkThesaurus(request) if err == nil { fmt.Printf("%+v\n", response) } else { fmt.Println(err) } } |
更多
更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。
状态码
状态码 |
描述 |
---|---|
200 |
请求已成功。 |
500 |
表明服务端能被请求访问到,但是不能理解用户的请求。 |
错误码
请参见错误码。