Rumah >pembangunan bahagian belakang >tutorial php >Carian Cina yang cekap dengan Elasticsearch

Carian Cina yang cekap dengan Elasticsearch

William Shakespeare
William Shakespeareasal
2025-02-19 08:28:11445semak imbas

Carian Cina Elasticsearch: Penganalisis dan Amalan Terbaik

Analisis dan leksikisasi adalah penting dalam indeks kandungan Elasticsearch, terutamanya ketika berurusan dengan bahasa bukan bahasa Inggeris. Bagi Cina, proses ini lebih rumit kerana ciri -ciri watak -watak Cina dan kekurangan ruang antara kata -kata dan ayat.

Artikel ini membincangkan beberapa penyelesaian untuk menganalisis kandungan Cina dalam Elasticsearch, termasuk penganalisis cina lalai, pemalam PAODING, CJK Analyzer, SmartCN Analyzer dan ICU plug-in, dan menganalisis kelebihan dan kekurangan mereka dan senario yang berkenaan.

Cabaran carian Cina

Watak -watak Cina adalah ideogram yang mewakili perkataan atau morfem (unit yang paling bermakna dalam bahasa). Apabila digabungkan bersama, maknanya akan berubah, mewakili perkataan yang sama sekali baru. Satu lagi kesukaran ialah tidak ada ruang antara kata -kata dan ayat, yang menjadikan sukar bagi komputer untuk mengetahui di mana perkataan bermula dan berakhir.

Walaupun anda hanya menganggap bahasa Mandarin (bahasa Cina rasmi dan orang Cina yang paling banyak digunakan di dunia), terdapat puluhan ribu watak Cina, walaupun anda sebenarnya menulis bahasa Cina, anda hanya perlu tahu tiga hingga empat ribu Watak cina. Sebagai contoh, "Volcano" (Volcano) sebenarnya gabungan dua watak Cina berikut:

  • api: api
  • gunung: gunung

Kata -kata kami mesti cukup pintar untuk mengelakkan memisahkan kedua -dua watak Cina ini, kerana makna mereka berbeza dari ketika mereka dipisahkan.

Kesukaran lain ialah varian ejaan yang digunakan:

  • Cina yang dipermudahkan: kaligrafi
  • Cina tradisional, lebih kompleks dan lebih kaya: Kaedah buku
  • pinyin, bentuk romanisasi mandarin: shū fǎ

Analyzer Cina di Elasticsearch

Pada masa ini, Elasticsearch menyediakan penganalisis Cina berikut:

  • Default Chinese Analyzer, berdasarkan kelas yang tidak disengajakan dalam Lucene 4;
  • plugin, walaupun tidak lagi dikekalkan, didasarkan pada kamus yang sangat baik; paoding
  • Analyzer, yang menghidupkan kandungan;
  • cjk Analyzer, plug-in yang disokong secara rasmi;
  • pemalam ICU dan peranti segmentasi perkataannya.
  • smartcn
  • Penganalisis ini sangat berbeza -beza, dan kami akan membandingkan prestasi mereka dengan perkataan ujian mudah "telefon bimbit". "Telefon bimbit" bermaksud "telefon bimbit", yang terdiri daripada dua watak Cina, yang mewakili "tangan" dan "mudah alih". Perkataan "ji" juga merupakan banyak perkataan lain:
Penerbangan: Tiket Udara

robot: robot
  • pistol mesin: pistol mesin
  • Peluang: Peluang
  • Participle kami tidak dapat memecah watak -watak Cina ini kerana jika saya mencari "telefon bimbit", saya tidak mahu apa -apa dokumentasi mengenai Rambo memiliki pistol mesin.
  • kami akan menguji penyelesaian ini menggunakan API
API yang kuat:

_analyze

  • Default Chinese Analyzer: Ia hanya membahagikan semua watak Cina ke dalam elemen perkataan. Oleh itu, kami mendapat dua elemen leksikal: telefon bimbit dan telefon bimbit. Analyzer standard menghasilkan output yang sama. Oleh itu, Chinese tidak lama lagi dan tidak lama lagi akan digantikan oleh standard dan harus dielakkan.

  • paoding plug-in: Hampir standard industri dan dianggap sebagai penyelesaian yang elegan. Malangnya, plugin untuk Elasticsearch tidak dikekalkan, dan saya hanya boleh menjalankannya pada versi 1.0.1 selepas beberapa pengubahsuaian. (Langkah -langkah pemasangan ditinggalkan, teks asal yang disediakan) Selepas pemasangan, kami mendapat segmen perkataan paoding baru dan dua pengumpul: paoding dan max_word_len. Secara lalai, tidak ada penganalisis awam, jadi kita perlu mengisytiharkan penganalisis baru. (Langkah -langkah konfigurasi ditinggalkan, teks asal disediakan) Kedua -dua konfigurasi memberikan hasil yang baik dengan unsur -unsur leksikal yang jelas dan unik. Ia juga berkelakuan baik apabila berurusan dengan ayat yang lebih kompleks. most_word

  • Analyzer: cjk Penganalisis yang sangat mudah yang hanya menukar teks ke dalam binari. "Telefon bimbit" hanya indeks , yang bagus, tetapi jika kita menggunakan kata -kata yang lebih panjang, seperti "Festival Lantern" (Festival Lantern), dua perkataan akan dihasilkan: Festival Lantern dan Festival Xiao, yang bermaksud "Festival Lantern" dan masing -masing "Festival Xiao". 手机

  • Plug-in: smartcn Sangat mudah dipasang. (Langkah -langkah pemasangan ditinggalkan, teks asal disediakan) Ia memperlihatkan penganalisis baru, serta smartcn segmen perkataan, menggunakan Lucene's smartcn_tokenizer. Ia menggunakan suite kebarangkalian untuk mencari segmentasi perkataan terbaik, menggunakan model Markov tersembunyi dan sejumlah besar teks latihan. Oleh itu, kamus latihan yang cukup baik telah tertanam -contoh -contoh kita adalah berstahan dengan betul. SmartChineseAnalyzer

  • Plugin ICU: Satu lagi plugin rasmi. (Langkah-langkah pemasangan ditinggalkan, teks asal disediakan) Jika anda berurusan dengan mana-mana bahasa bukan bahasa Inggeris, disarankan untuk menggunakan plugin ini. Ia mendedahkan segmen perkataan , serta banyak alat analisis yang kuat seperti icu_tokenizer, icu_normalizer, icu_folding, dan lain -lain. Ia menggunakan kamus Cina dan Jepun yang mengandungi maklumat mengenai kekerapan perkataan untuk menyimpulkan kumpulan watak Cina. Pada "telefon bimbit", semuanya normal dan berfungsi seperti yang diharapkan, tetapi pada "Festival Lantern", dua perkataan akan dihasilkan: Festival Lantern dan Festival - Ini kerana "Festival Lantern" dan "Festival" lebih penting daripada "Festival Lantern ". Biasa. icu_collation

perbandingan hasil (borang yang ditinggalkan, teks asal disediakan)

Dari sudut pandangan saya,

dan paoding mendapat hasil yang terbaik. smartcn Kata participle sangat buruk, chinese agak mengecewakan pada "Festival Lantern", tetapi sangat baik untuk berurusan dengan Cina tradisional. icu_tokenizer

sokongan tradisional Cina

Anda mungkin perlu memproses Cina tradisional dari dokumen atau permintaan carian pengguna. Anda memerlukan langkah normalisasi untuk menukar input tradisional ini ke dalam bahasa Cina moden kerana plugin seperti smartcn atau paoding jangan mengendalikannya dengan betul.

Anda boleh mengendalikannya melalui aplikasi anda, atau cuba menggunakan plugin elasticsearch-analysis-stconvert untuk mengendalikannya secara langsung di Elasticsearch. Ia boleh menukar watak tradisional dan mudah di kedua -dua arah. (Langkah pemasangan ditinggalkan, teks asal telah disediakan)

Penyelesaian terakhir adalah menggunakan cjk: jika anda tidak dapat memasukkan participle dengan betul, anda masih sangat mungkin menangkap dokumentasi yang diperlukan dan kemudian gunakan icu_tokenizer (juga cukup baik) untuk meningkatkan kaitan.

Penambahbaikan selanjutnya

Tidak ada penyelesaian sejagat yang sempurna untuk analisis Elasticsearch, dan Cina tidak terkecuali. Anda mesti menggabungkan dan membina penganalisis anda sendiri berdasarkan maklumat yang telah anda perolehi. Sebagai contoh, saya menggunakan participle cjk dan smartcn pada medan carian, menggunakan pertanyaan berbilang bidang dan multi-perlawanan.

(bahagian FAQ ditinggalkan, teks asal disediakan)

Atas ialah kandungan terperinci Carian Cina yang cekap dengan Elasticsearch. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn