Ответ 1
В этом посте я предоставлю вам три разных способа делать то, что вы просите. Я действительно рекомендую использовать последний фрагмент, так как он проще всего понять, а также быть довольно аккуратным в коде.
Как узнать, какие элементы в массиве соответствуют моему регулярному выражению?
Для этой цели существует функция, preg_grep
. Он примет регулярное выражение как первый параметр, а массив - второй.
См. пример ниже:
$haystack = array (
'say hello',
'hello stackoverflow',
'hello world',
'foo bar bas'
);
$matches = preg_grep ('/^hello (\w+)/i', $haystack);
print_r ($matches);
Выход
Array
(
[1] => hello stackoverflow
[2] => hello world
)
Документация
Но я просто хочу получить значение указанных групп. Как?
array_reduce
с preg_match
может решить эту проблему чистым образом; см. ниже фрагмент.
$haystack = array (
'say hello',
'hello stackoverflow',
'hello world',
'foo bar bas'
);
function _matcher ($m, $str) {
if (preg_match ('/^hello (\w+)/i', $str, $matches))
$m[] = $matches[1];
return $m;
}
// N O T E :
// ------------------------------------------------------------------------------
// you could specify '_matcher' as an anonymous function directly to
// array_reduce though that kind of decreases readability and is therefore
// not recommended, but it is possible.
$matches = array_reduce ($haystack, '_matcher', array ());
print_r ($matches);
Выход
Array
(
[0] => stackoverflow
[1] => world
)
Documentation
Использование array_reduce
кажется утомительным, нет другого пути?
Да, и этот режим действительно более чистый, хотя он не предполагает использование ранее существовавшей функции array_*
или preg_*
.
Оберните его в функцию, если вы собираетесь использовать этот метод более одного раза.
$matches = array ();
foreach ($haystack as $str)
if (preg_match ('/^hello (\w+)/i', $str, $m))
$matches[] = $m[1];
Documentation