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

ICU

icu トークナイザーは、ソフトウェアの国際化のための主要なツールを提供する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 は指定されたアナライザーを使用してそのフィールドのテキストを処理し、効率的なトークン化とフィルタリングを行います。詳細については、使用例を参照してください。

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

アナライザー設定

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)

期待される出力

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