zoukankan      html  css  js  c++  java
  • 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对应的值。

    示例代码一:

    $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
    )

    示例代码二:

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

    输出:

    Array
    (
      [2135] => Doe
      [3245] => Smith
      [5342] => Jones
      [5623] => Doe
    )

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

    使用array_map()实现例一:

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

    使用foreach实现例一:

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

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

  • 相关阅读:
    使用Astah画UML类图经验总结
    Qt的四个常见的图像叠加模式
    获取Linux时间函数
    DBus学习网站
    线程属性pthread_attr_t简介
    Secure CRT 自动记录日志log配置
    MySQL的group_concat()函数合并多行数据
    MySQL的Limit详解
    异步查询json传日期格式到前台,变成了时间戳的格式
    启动studio报错Gradle error
  • 原文地址:https://www.cnblogs.com/-mrl/p/7567157.html
Copyright © 2011-2022 走看看