如果您无法升级php版本,可以简单地使用以下语法。在这种情况下,使用
if (!function_exists('array_column'))
来防止函数重新声明,这可能会在版本升级时发生。
php.net的描述
array_column()
返回数组中单个列的值,由column_key标识。 可选地,您可以提供一个index_key,将返回的数组中的值按输入数组中index_key列中的值进行索引。
if (!function_exists('array_column'))
{
function array_column(array $array, $column_key, $index_key = NULL)
{
if (isset($array))
{
$return = array();
foreach ($array as $a)
{
if ($index_key)
{
if (!isset($a[$index_key]))
{
return array();
}
else
{
$return[$a[$index_key]] = $a[$column_key];
}
}
else
{
$return[] = $a[$column_key];
}
}
return $return;
}
return array();
}
}
以下是从
PHP.NET 获取的一些示例。
<?php
$records = array(
array(
'id' => 2135,
'first_name' => 'John',
'last_name' => 'Doe',
),
array(
'id' => 3245,
'first_name' => 'Sally',
'last_name' => 'Smith',
),
array(
'id' => 5342,
'first_name' => 'Jane',
'last_name' => 'Jones',
),
array(
'id' => 5623,
'first_name' => 'Peter',
'last_name' => 'Doe',
)
);
$first_names = array_column($records, 'first_name');
print_r($first_names);
?>
它将会产生以下输出:
Array
(
[0] => John
[1] => Sally
[2] => Jane
[3] => Peter
)
从记录集中获取姓氏列,由“id”列索引。
<?php
$last_names = array_column($records, 'last_name', 'id');
print_r($last_names);
?>
它将会输出以下内容:
Array
(
[2135] => Doe
[3245] => Smith
[5342] => Jones
[5623] => Doe
)