Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mengabaikan Ruang Putih Pilihan dalam Ungkapan Biasa untuk Penghuraian HTML?

Bagaimana untuk Mengabaikan Ruang Putih Pilihan dalam Ungkapan Biasa untuk Penghuraian HTML?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-24 08:29:01640semak imbas

How to Ignore Optional Whitespace in Regular Expressions for HTML Parsing?

Ruang Putih Pilihan dalam Ungkapan Biasa

Apabila menghuraikan HTML atau data teks, mengabaikan ruang kosong antara aksara tertentu selalunya diperlukan. Walau bagaimanapun, ini boleh mencabar menggunakan ungkapan biasa.

Penyelesaian Menggunakan s? dan s* Pengkuantiti

Untuk memadankan ruang kosong pilihan antara aksara, gunakan pengkuantiti s? dan s*.

  • s sepadan dengan mana-mana aksara ruang putih (ruang, tab, baris baharu, dll.).
  • ? bermaksud aksara sebelumnya mungkin berlaku sekali atau tidak sama sekali.
  • * bermaksud aksara sebelumnya mungkin berlaku sifar atau lebih kali.

Contoh

Untuk mengabaikan ruang putih dalam teg HTML berikut:

<code class="html"><a href="/wiki/File:Sky1.png" title="File:Sky1.png">
<img alt="Sky1.png" src="http://media-mcw.cursecdn.com/thumb/5/56/Sky1.png/150px-Sky1.png" width="150" height="84">
</a></code>

Gunakan ungkapan biasa berikut:

'#<a href\s?="(.*?)" title\s?="(.*?)"><img alt\s?="(.*?)" src\s?="(.*?)"[\s*]width\s?="150"[\s*]height\s?="(.*?)"></a>#'

Ungkapan ini membenarkan ruang kosong pilihan antara nama atribut dan nilainya, serta antara nilai atribut dan teg HTML di sekelilingnya.

Nota tentang Kelas Aksara

Kod asal menggunakan kelas aksara [s ], yang menyebabkan hasil yang tidak dijangka. Kelas aksara memadankan mana-mana ahlinya sekali, dan pengkuantiti membenarkannya berlaku beberapa kali. Dengan menggantikan [s] dengan s, anda memastikan bahawa hanya aksara ruang putih dipadankan dan pengkuantiti digunakan padanya secara khusus.

Atas ialah kandungan terperinci Bagaimana untuk Mengabaikan Ruang Putih Pilihan dalam Ungkapan Biasa untuk Penghuraian HTML?. 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