C# Pemisahan Ungkapan Biasa: Mengendalikan Koma dalam Rentetan Petikan
Pemisahan rentetan berasaskan koma C# standard gagal apabila berurusan dengan koma dalam teks yang dipetik. Ungkapan biasa memberikan penyelesaian yang mantap.
Pertimbangkan untuk memisahkan rentetan "('ABCDEFG', 123542, 'XYZ 99,9')" kepada tiga bahagian konstituennya: 'ABCDEFG', 123542 dan 'XYZ 99,9'.
Ungkapan biasa berikut mengenal pasti koma di luar bahagian yang dipetik:
<code class="language-csharp">",(?=(?:[^']*'[^']*')*[^']*$)"</code>
Ungkapan ini memastikan bahawa hanya koma yang tidak didahului oleh bilangan genap petikan tunggal (menunjukkan bahagian petikan tertutup) digunakan sebagai titik selisih.
Begini cara menggunakannya dengan Regex.Split
:
<code class="language-csharp">string inputString = "('ABCDEFG', 123542, 'XYZ 99,9')"; string[] splitString = Regex.Split(inputString, ",(?=(?:[^']*'[^']*')*[^']*$)");</code>
Tatasusunan splitString
kemudiannya akan mengandungi:
splitString[0]
= 'ABCDEFG'splitString[1]
= 123542splitString[2]
= 'XYZ 99,9'Pendekatan ungkapan biasa ini memisahkan rentetan dengan tepat, memelihara integriti data walaupun koma muncul dalam subrentetan yang disebut.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memisahkan Rentetan Dipisahkan Koma dalam C# Semasa Mengabaikan Koma Dalam Petikan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!