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

ICU

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

📘注意

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

設定

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

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

icu トークナイザーは、1つ以上のフィルターと連携して動作できます。たとえば、以下のコードは icu トークナイザーと remove punct filter を使用するアナライザーを定義しています:

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 = "Привет! Как дела?"

# 定義された設定で標準アナライザーを実行
result = client.run_analyzer(sample_text, analyzer_params)
print("Standard analyzer output:", result)

期待される出力

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