array_find

Returns the first element satisfying a callback function

Description

mixed array_find(array $array, callable $callback)

array_find returns the value of the first element of an array for which the given callback returns true. If no matching element is found the function returns null.

Parameters

array
The array that should be searched.
callback

The callback function to call to check each element, which must be

bool callback(mixed $value, mixed $key)
If this function returns true, the value is returned from array_find and the callback will not be called for further elements.

Return Values

The function returns the value of the first element for which the callback returns true. If no matching element is found the function returns null.

Examples

Example #1 array_find example

<?php
$array = [
    'a' => 'dog',
    'b' => 'cat',
    'c' => 'cow',
    'd' => 'duck',
    'e' => 'goose',
    'f' => 'elephant'
];

// Find the first animal with a name longer than 4 characters.
var_dump(array_find($array, function (string $value) {
    return strlen($value) > 4;
}));

// Find the first animal whose name begins with f.
var_dump(array_find($array, function (string $value) {
    return str_starts_with($value, 'f');
}));

// Find the first animal where the array key is the first symbol of the animal.
var_dump(array_find($array, function (string $value, $key) {
   return $value[0] === $key;
}));

// Find the first animal where the array key matching a RegEx.
var_dump(array_find($array, function ($value, $key) {
   return preg_match('/^([a-f])$/', $key);
}));
?>

The above example will output:

string(5) "goose"
NULL
string(3) "cow"
string(3) "dog"

See Also

  • array_find_key
  • array_all
  • array_any
  • array_filter
  • array_reduce