メインコンテンツまでスキップ
バージョン: User Guides (Cloud)

ICU

icu トークナイザーは、Internationalization Components of Unicode(ICU)オープンソースプロジェクトをベースに構築されています。ICU はソフトウェアの国際化に不可欠なツールを提供しており、その単語分割アルゴリズムを使用することで、世界のほとんどの言語においてテキストを正確に単語に分割できます。

📘Notes

icu トークナイザーは、出力において句読点とスペースを個別のトークンとして保持します。例えば、"Привет! Как дела?"["Привет", "!", " ", "Как", " ", "дела", "?"] となります。これらの独立した句読点トークンを削除するには、removepunct フィルターを使用してください。

設定

icu トークナイザーを使用してアナライザーを設定するには、analyzer_paramstokenizericu に設定します。

analyzer_params = {
"tokenizer": "icu",
}

icu トークナイザーは、1 つ以上のフィルターと組み合わせて使用できます。たとえば、次のコードでは、icu トークナイザーと remove punct フィルター を使用するアナライザーを定義しています。

analyzer_params = {
"tokenizer": "icu",
"filter": ["removepunct"]
}

analyzer_params を定義した後、コレクションスキーマを定義する際に VARCHAR フィールドに適用できます。これにより、Zilliz Cloud は指定したアナライザーを使用してそのフィールドのテキストを処理し、効率的なトークン化とフィルタリングを行うことができます。詳細については、使用例 を参照してください。

Examples

アナライザー設定をコレクションスキーマに適用する前に、run_analyzer メソッドを使用してその動作を確認してください。

Analyzer configuration

analyzer_params = {
"tokenizer": "icu",
}

run_analyzer を使用した検証

from pymilvus import (
MilvusClient,
)

client = MilvusClient(
uri="YOUR_CLUSTER_ENDPOINT",
token="YOUR_CLUSTER_TOKEN"
)

# Sample text to analyze
sample_text = "Привет! Как дела?"

# Run the standard analyzer with the defined configuration
result = client.run_analyzer(sample_text, analyzer_params)
print("Standard analyzer output:", result)

期待される出力

['Привет', '!', ' ', 'Как', ' ', 'дела', '?']