Funkcija preg_match
Funkcija preg_match meklē virknē atbilstības ar regulāro izteiksmi. Pirmo parametru pieņem kā regulārās izteiksmes veidni, otro - kā virkni meklēšanai, trešo (neobligāto) - kā masīvu atrasto atbilstību saglabāšanai, ceturto (neobligāto) - karogus, piekto (neobligāto) - meklēšanas sākuma nobīdi.
Sintakse
preg_match(pattern, subject, [matches], [flags], [offset]);
Karogi
| Karogs | Konstante | Apraksts |
|---|---|---|
PREG_PATTERN_ORDER |
1 | Rezultāti tiek sakārtoti pēc veidnēm (pēc noklusējuma) |
PREG_SET_ORDER |
2 | Rezultāti tiek sakārtoti pēc atbilstību kopām |
PREG_OFFSET_CAPTURE |
256 | Atgriež atbilstības pozīciju virknē |
PREG_UNMATCHED_AS_NULL |
512 | Neatbilstošie apakšveidnes tiek atgrieztas kā NULL |
Piemērs
Pārbaudīsim, vai virkne satur ciparus:
<?php
$res = preg_match('/\d+/', 'abc123');
echo $res;
?>
Koda izpildes rezultāts:
1
Piemērs
Iegūstam visus ciparus no virknes masīvā:
<?php
preg_match('/\d+/', 'abc123', $matches);
var_dump($matches);
?>
Koda izpildes rezultāts:
[0 => '123']
Piemērs
Nosauktu grupu izmantošana regulārajā izteiksmē:
<?php
preg_match('/(?P<name>\w+)\s+(?P<age>\d+)/', 'John 25', $matches);
var_dump($matches);
?>
Koda izpildes rezultāts:
[
0 => 'John 25',
'name' => 'John',
1 => 'John',
'age' => '25',
2 => '25'
]
Piemērs
Karoga PREG_OFFSET_CAPTURE izmantošana, lai iegūtu atbilstības pozīciju:
<?php
preg_match('/\d+/', 'abc123', $matches, PREG_OFFSET_CAPTURE);
var_dump($matches);
?>
Koda izpildes rezultāts:
[
0 => [
0 => '123',
1 => 3
]
]
Piemērs
Meklēšana ar nobīdes (offset) norādīšanu:
<?php
preg_match('/\d+/', '123abc456', $matches, 0, 3);
var_dump($matches);
?>
Koda izpildes rezultāts:
[0 => '456']
Piemērs
E-pasta adreses derīguma pārbaude:
<?php
$email = 'test@example.com';
$res = preg_match('/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/', $email);
echo $res ? 'Valid' : 'Invalid';
?>
Koda izpildes rezultāts:
'Valid'
Skatiet arī
-
funkciju
preg_match_all,
kura meklē visas atbilstības virknē -
funkciju
preg_replace,
kura veic aizstāšanu pēc regulārās izteiksmes