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

ICU

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

📘Notes

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

設定

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

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 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)

期待される出力

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