
理解问题:array_values()的局限性
在php开发中,我们经常会遇到包含多层结构的数组。例如,一个主数组可能包含多个子数组,每个子数组又以一个特定的键(如'item')存储着另一个数组,其中包含了我们真正需要的数据。
考虑以下数据结构:
$data = [
'first_entry' => [
'item' => [
'name' => '商品A',
'price' => 100,
'quantity' => 1
],
'other_info' => '一些其他信息'
],
'second_entry' => [
'item' => [
'name' => '商品B',
'price' => 150,
'quantity' => 2
],
'other_info' => '更多信息'
],
'third_entry' => [
'item' => [
'name' => '商品C',
'price' => 200,
'quantity' => 1
]
]
];我们的目标是从$data数组中提取所有'item'键对应的子数组,并将它们组织成一个不包含外层键的新数组,期望的输出如下:
[
[
'name' => '商品A',
'price' => 100,
'quantity' => 1
],
[
'name' => '商品B',
'price' => 150,
'quantity' => 2
],
[
'name' => '商品C',
'price' => 200,
'quantity' => 1
]
]初学者可能会尝试使用array_values()函数。然而,array_values()的作用是返回数组中所有值的新数组,并用数字索引重新排列。当应用于上述$data数组时,它会移除'first_entry'、'second_entry'等顶级键,但其值仍然是包含'item'键的子数组:
$result_array_values = array_values($data); // 输出会是: // [ // 0 => [ 'item' => [...], 'other_info' => '...' ], // 1 => [ 'item' => [...], 'other_info' => '...' ], // 2 => [ 'item' => [...] ] // ]
这显然不是我们想要的结果,因为它并没有“深入”到每个子数组中去提取'item'的值。
立即学习“PHP免费学习笔记(深入)”;
解决方案:array_column()函数
PHP提供了array_column()函数,它正是为解决此类问题而设计的。array_column()用于返回输入数组中某个单一列的值。
Scala也是一种函数式语言,其函数也能当成值来使用。Scala提供了轻量级的语法用以定义匿名函数,支持高阶函数,允许嵌套多层函数,并支持柯里化 。Scala的Case Class及其内置的模式匹配相当于函数式编程语言中常用的代数类型(Algebraic Type)。 Scala课堂是Twitter启动的一系列讲座,用来帮助有经验的工程师成为高效的Scala 程序员。Scala是一种相对较新的语言,但借鉴了许多熟悉的概念。因此,课程中的讲座假设听众知道这些概念,并展示了如何在Scala中使用它们。我们发现
array_column()语法
array_column(array $array, mixed $column_key, mixed $index_key = null): array
- $array: 必需。指定要处理的多维数组(或对象数组)。
- $column_key: 必需。指定要返回值的列的键。它可以是整数索引,也可以是字符串键名。如果指定为null,则返回所有列。
- $index_key: 可选。指定用作返回数组的索引的列的键。
实际应用示例
针对我们之前的需求,我们需要从$data数组的每个子元素中提取'item'键对应的值。我们可以这样使用array_column():
[
'item' => [
'name' => '商品A',
'price' => 100,
'quantity' => 1
],
'other_info' => '一些其他信息'
],
'second_entry' => [
'item' => [
'name' => '商品B',
'price' => 150,
'quantity' => 2
],
'other_info' => '更多信息'
],
'third_entry' => [
'item' => [
'name' => '商品C',
'price' => 200,
'quantity' => 1
]
]
];
// 使用 array_column 提取所有 'item' 键的值
$extractedItems = array_column($data, 'item');
echo "";
print_r($extractedItems);
echo "
";
?>输出结果
执行上述代码将得到我们期望的输出:
Array
(
[0] => Array
(
[name] => 商品A
[price] => 100
[quantity] => 1
)
[1] => Array
(
[name] => 商品B
[price] => 150
[quantity] => 2
)
[2] => Array
(
[name] => 商品C
[price] => 200
[quantity] => 1
)
)可以看到,array_column($data, 'item')精确地从$data数组的每个顶级元素中找到了键为'item'的子数组,并将这些子数组收集起来,形成了一个新的、扁平化的数组。
总结与注意事项
- array_column()的优势:当需要从一个包含多个子数组的数组中,提取所有子数组内某个特定键的值时,array_column()是最高效和简洁的方法。它能够“深入”到数组的第二层(或更深,如果$column_key是多级路径的一部分,尽管这通常通过循环或递归实现),直接提取所需的数据。
- 与array_values()的区别:array_values()仅作用于当前数组的顶级键,将其值作为新数组的元素,并重新索引。它不会改变或提取嵌套数组内部的结构。
- 处理不存在的键:如果某个子数组中不存在$column_key指定的键,array_column()会为该位置返回null,而不是抛出错误,这增加了其健壮性。
- 性能:array_column()是C语言实现的内置函数,在处理大量数据时,其性能通常优于手动循环遍历数组并提取值的做法。
通过掌握array_column()函数,开发者可以更高效、更优雅地处理PHP中的复杂数组数据结构,从而提升代码质量和执行效率。










