


Ungkapan biasa untuk mengecualikan teks antara kurungan daripada padanan
editor php Banana memperkenalkan anda kepada alat pemprosesan rentetan yang berkuasa dan biasa digunakan - ungkapan biasa. Ungkapan biasa boleh mengecualikan teks antara kurungan apabila memadankan rentetan, yang sangat berguna apabila memproses data teks yang kompleks. Melalui peraturan sintaks yang mudah, kami boleh menapis dan mengekstrak rentetan dengan mudah, meningkatkan kecekapan dan ketepatan pemprosesan data. Sama ada anda sedang membangunkan halaman web, memproses data atau melakukan analisis teks, menguasai ungkapan biasa ialah kemahiran penting. Mari belajar ungkapan biasa bersama-sama dan meningkatkan keupayaan pemprosesan rentetan kami!
Isi soalan
Diberi teks berikut:
{field1} == value1 && {field2} == value2 && ({field3} == value3 && {field4} == value4) && {field5} == value5
Saya cuba mencipta satu dengan semua &&
匹配的正则表达式,但排除括号之间的内容(因此 value3 和 field4 之间的 && 应被忽略)。我已经能够使用以下正则表达式来完成此操作: (&{2})(?![^(]*))
pada teks itu [ini berfungsi dan sedang melakukan apa yang saya perlukan] tetapi masalahnya ialah saya menggunakan golang, yang tidak menyokong pandangan negatif. Adakah terdapat cara untuk melakukannya tanpa pandangan negatif? Tanda kurung tidak boleh bersarang.
Pada asasnya saya ingin berpecah dengan &&
tetapi abaikan apa yang ada di antara kurungan dan dapatkan sesuatu seperti:
[&&, &&, &&] [{field1} == value1, {field2} == value2, ({field3} == value3 && {field4} == value4), {field5} == value5]
Terima kasih!
Penyelesaian
Anda boleh menggunakan teknik yang anda memadankan semua yang anda tidak mahu, tetapi jangan tangkapnya, dan padankan serta tangkap semua yang anda inginkan (iaitu simpan ke kumpulan tangkapan). Anda boleh menggunakan ungkapan biasa berikut untuk melakukan ini.
\([^\]]*\)|(&&)
berbunyi "Padankan rentetan yang disertakan dalam kurungan atau (|
) 匹配字符串 ”&&“
dan simpannya untuk menangkap kumpulan 1". Ideanya ialah (dalam kod) untuk mengabaikan padanan yang tidak ditangkap.
Untuk rentetan berikut, tunjukkan padanan (diwakili oleh "m"
s 表示)和捕获(由 "c"
s).
{f1} == v1 && {f2} == v2 && ({f3} == v3 && {f4} == v4) && {f5} == v5 mm mmmmmmmmmmmmmmmmmmmmmmmmmm mm cc cc
perlawanan dalam rentetan ({
)的开头,([^]]*)
和 (&&)
都不匹配,因此字符串指针前进一位到 f
。同样,没有匹配项,因此字符串指针又前进一个字符,指向 1
。这将继续(没有匹配项),直到到达第一个 &
。 ([^]]*)
不匹配,但 (&&)
. Kami berminat dengan perlawanan ini kerana telah berjaya ditawan (menangkap kumpulan 1).
Penuding rentetan kemudian bergerak ke hadapan satu aksara pada satu masa, tidak menemui padanan lagi, sehingga ia mencapai perlawanan (
。此时,({f3} == v3 && {f4} == v4)
与 ([^]]*)
, tetapi kerana ia tidak ditangkap, kami tidak mempedulikannya. Ini berterusan sehingga hujung rentetan dicapai.
Sebagai alternatif, kita boleh menggunakan ungkapan biasa
\([^\]]*\)|&&
Dan semak watak pertama setiap perlawanan. Jika (
kami berputus asa memandangkan perlawanan itu.
Apabila setiap kejadian &&
ditemui, kami mungkin (dalam kod) menggantikannya dengan rentetan lain (mungkin kosong), dapatkan offsetnya dalam rentetan (untuk tujuan tertentu) atau Cuma tambahkan pembilang bilangan padanan dalam rentetan. Ini sudah tentu bergantung pada mengapa kita mahu memadankan rentetan ini.
Atas ialah kandungan terperinci Ungkapan biasa untuk mengecualikan teks antara kurungan daripada padanan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

Laluan Pembelajaran Backend: Perjalanan Eksplorasi dari Front-End ke Back-End sebagai pemula back-end yang berubah dari pembangunan front-end, anda sudah mempunyai asas Nodejs, ...

Artikel ini membincangkan menguruskan kebergantungan modul Go melalui Go.Mod, meliputi spesifikasi, kemas kini, dan resolusi konflik. Ia menekankan amalan terbaik seperti versi semantik dan kemas kini biasa.

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a
