欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

PHP中array_map与array_column之间的关系分析

shiping1 的头像

PHP中array_map与array_column之间的关系分析

投稿:shichen2014 字体:[增加 减小] 类型:转载 时间:2014-08-19 我要评论

这篇文章主要介绍了PHP中array_map与array_column之间的关系分析,对于PHP初学者来说是比较实用的概念,需要的朋友可以参考下
 

本文以实例形式分析了PHP中array_map与array_column之间的关系,具体分析如下:

array_map()与array_column()用法如下:

array_map();将回调函数作用到给定数组的单元上
array_column();快速实现:将二维数组转为一维数组

array_column()函数格式为:

array array_column ( array $input , mixed $column_key [, mixed $index_key ] );

返回input数组中值为column_key的列; 如果指定了可选参数index_key,返回的数组中 对应键 为input数组值index_key对应的值。

示例代码一:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
$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);

输出:

1
2
3
4
5
6
7
Array
(
  [0] => John
  [1] => Sally
  [2] => Jane
  [3] => Peter
)

示例代码二:

1
2
$last_names = array_column($records, 'last_name', 'id');
print_r($last_names);

输出:

1
2
3
4
5
6
7
Array
(
  [2135] => Doe
  [3245] => Smith
  [5342] => Jones
  [5623] => Doe
)

当没有array_column()函数情况下,

使用array_map()实现例一:

1
2
3
$a = array_map(function($element){  //$records作为参数传入回调函数
  return $element['last_name'];  //返回数组元素值的last_name对应值
}, $records);            //array_map返回数组,相当于把每个$element['last_name']存入新数组,所以是新建的索引

使用foreach实现例一:

1
2
3
4
foreach($records as $v)
{
  $b[] = $v['last_name'];
}
1
2
3
4
5
6
使用foreach实现例二:
$c = array();
foreach($records as $k=>$v)
{
 $c += array($v['id']=>$v['last_name']); //使用+运算符, 以追加的形式(不改变原数组索引), 合并组装的数组
}                 //若使用array_merge,数字键名将被重新编号

在取出的多条数据中,典型的二维数组,如果需要使用数据中单一的值与值对应的情况,array_column()即可完成,但是面对较复杂的数组结构,foreach才能让你更灵活,不过优先使用系统函数总是首选的。


来自 http://www.jb51.net/article/53976.htm
普通分类: