Menggunakan ungkapan biasa untuk memisahkan rentetan dalam C#: memproses koma dalam petikan
Dalam pelbagai senario seperti penghuraian data atau operasi rentetan SQL, rentetan yang mengandungi koma mungkin perlu dipisahkan menggunakan ungkapan biasa. Walau bagaimanapun, cabaran timbul apabila koma muncul di dalam dan di luar tanda petikan.
Mari kita pertimbangkan rentetan berikut:
<code>('ABCDEFG', 123542, 'XYZ 99,9')</code>
Matlamat kami adalah untuk memisahkan rentetan ini kepada bahagian komponennya menggunakan ungkapan biasa untuk mendapatkan output berikut:
Kuncinya ialah mengenali koma di luar tanda petikan. Untuk ini kita boleh menggunakan corak ungkapan biasa yang berkuasa:
<code>",(?=(?:[^']*'[^']*')*[^']*$)"</code>
Mari pecahkan corak ini:
"
: Memadankan koma literal.
(?=(?:[^']*'[^']*')*[^']*$)
: Ini ialah pernyataan pandangan ke hadapan yang menyemak sama ada koma diikuti dengan bilangan petikan genap.
(?:[^']*'[^']*')*
: Memadankan sebarang bilangan pasangan petikan tunggal dengan kandungan di antaranya. [^']*$
: Memadankan mana-mana aksara selepas tanda petikan terakhir, tetapi tidak termasuk tanda petikan. Dengan menggunakan corak ini, kami boleh memadankan mana-mana koma yang diikuti dengan bilangan petikan genap, dengan berkesan memastikan kami hanya memisahkan rentetan di luar petikan.
Untuk menggunakan ungkapan biasa ini untuk pemisahan kami akan menggunakan kod C# berikut:
<code class="language-csharp">var result = Regex.Split(samplestring, ",(?=(?:[^']*'[^']*')*[^']*$)");</code>
Selepas melaksanakan kod ini, result
akan mengandungi tatasusunan rentetan, setiap rentetan mewakili komponen rentetan asal, dipecah mengikut syarat yang diingini.
Atas ialah kandungan terperinci Bagaimana untuk Memisahkan Rentetan dalam C# Menggunakan Regex untuk Mengendalikan Koma Dalam Petikan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!