Функция preg_match
Функцията preg_match търси съвпадения в низ с регулярен израз. Приема като първи параметър шаблон на регулярен израз, като втори - низ за търсене, като трети (незадължителен) - масив за запазване на намерените съвпадения, като четвърти (незадължителен) - флагове, като пети (незадължителен) - отместване за начало на търсене.
Синтаксис
preg_match(pattern, subject, [matches], [flags], [offset]);
Флагове
| Флаг | Константа | Описание |
|---|---|---|
PREG_PATTERN_ORDER |
1 | Резултатите се сортират по шаблони (по подразбиране) |
PREG_SET_ORDER |
2 | Резултатите се сортират по групи съвпадения |
PREG_OFFSET_CAPTURE |
256 | Връща позицията на съвпадението в низа |
PREG_UNMATCHED_AS_NULL |
512 | Несъвпадащите подшаблони се връщат като NULL |
Пример
Проверяваме дали низът съдържа цифри:
<?php
$res = preg_match('/\d+/', 'abc123');
echo $res;
?>
Резултат от изпълнението на кода:
1
Пример
Извличаме всички цифри от низа в масив:
<?php
preg_match('/\d+/', 'abc123', $matches);
var_dump($matches);
?>
Резултат от изпълнението на кода:
[0 => '123']
Пример
Използване на именувани групи в регулярен израз:
<?php
preg_match('/(?P<name>\w+)\s+(?P<age>\d+)/', 'John 25', $matches);
var_dump($matches);
?>
Резултат от изпълнението на кода:
[
0 => 'John 25',
'name' => 'John',
1 => 'John',
'age' => '25',
2 => '25'
]
Пример
Използване на флага PREG_OFFSET_CAPTURE за получаване на позицията на съвпадението:
<?php
preg_match('/\d+/', 'abc123', $matches, PREG_OFFSET_CAPTURE);
var_dump($matches);
?>
Резултат от изпълнението на кода:
[
0 => [
0 => '123',
1 => 3
]
]
Пример
Търсене с указано отместване (offset):
<?php
preg_match('/\d+/', '123abc456', $matches, 0, 3);
var_dump($matches);
?>
Резултат от изпълнението на кода:
[0 => '456']
Пример
Проверка на валидност на email адрес:
<?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';
?>
Резултат от изпълнението на кода:
'Valid'
Вижте също
-
функцията
preg_match_all,
която търси всички съвпадения в низ -
функцията
preg_replace,
която извършва замяна по регулярен израз