Funkce preg_match
Funkce preg_match hledá v řetězci shody s regulárním výrazem. Prvním parametrem přijímá vzor regulárního výrazu, druhým - řetězec pro hledání, třetím (nepovinným) - pole pro uložení nalezených shod, čtvrtým (nepovinným) - příznaky, pátým (nepovinným) - posun začátku hledání.
Syntaxe
preg_match(pattern, subject, [matches], [flags], [offset]);
Příznaky
| Příznak | Konstanta | Popis |
|---|---|---|
PREG_PATTERN_ORDER |
1 | Výsledky jsou řazeny podle vzorů (výchozí) |
PREG_SET_ORDER |
2 | Výsledky jsou řazeny podle sad shod |
PREG_OFFSET_CAPTURE |
256 | Vrací pozici shody v řetězci |
PREG_UNMATCHED_AS_NULL |
512 | Neshodující se dílčí vzory jsou vráceny jako NULL |
Příklad
Zkontrolujeme, zda řetězec obsahuje číslice:
<?php
$res = preg_match('/\d+/', 'abc123');
echo $res;
?>
Výsledek provedení kódu:
1
Příklad
Extrahujeme všechny číslice z řetězce do pole:
<?php
preg_match('/\d+/', 'abc123', $matches);
var_dump($matches);
?>
Výsledek provedení kódu:
[0 => '123']
Příklad
Použití pojmenovaných skupin v regulárním výrazu:
<?php
preg_match('/(?P<name>\w+)\s+(?P<age>\d+)/', 'John 25', $matches);
var_dump($matches);
?>
Výsledek provedení kódu:
[
0 => 'John 25',
'name' => 'John',
1 => 'John',
'age' => '25',
2 => '25'
]
Příklad
Použití příznaku PREG_OFFSET_CAPTURE pro získání pozice shody:
<?php
preg_match('/\d+/', 'abc123', $matches, PREG_OFFSET_CAPTURE);
var_dump($matches);
?>
Výsledek provedení kódu:
[
0 => [
0 => '123',
1 => 3
]
]
Příklad
Hledání s určením posunu (offset):
<?php
preg_match('/\d+/', '123abc456', $matches, 0, 3);
var_dump($matches);
?>
Výsledek provedení kódu:
[0 => '456']
Příklad
Kontrola platnosti emailové adresy:
<?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';
?>
Výsledek provedení kódu:
'Valid'
Viz také
-
funkci
preg_match_all,
která hledá všechny shody v řetězci -
funkci
preg_replace,
která provádí nahrazení podle regulárního výrazu