• PHP 获取二维数组中某个key的集合


    本文为代码分享,也是在工作中看到一些“大牛”的代码,做做分享。

    具体是这样的,如下一个二维数组,是从库中读取出来的。

    代码清单:

    [php] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. $user = array(  
    2.     0 => array(  
    3.         'id'    => 1,  
    4.         'name'  => '张三',  
    5.         'email' => 'zhangsan@sina.com',  
    6.     ),  
    7.     1 => array(  
    8.         'id'    => 2,  
    9.         'name'  => '李四',  
    10.         'email' => 'lisi@163.com',  
    11.     ),  
    12.     2 => array(  
    13.         'id'    => 5,  
    14.         'name'  => '王五',  
    15.         'email' => '10000@qq.com',  
    16.     ),  
    17.     ......  
    18. );  


    上面的数组格式,主要大家玩过 PHP+MYSQL,就肯定非常熟悉了。

    那么,现在有这样的两个需求:

    1)获取索引"id"的集合,并且保存为一个一位数组,即得到 array(1,2,5)

    不知道各位朋友会怎么写呢?

    如果是以前我的写法就是直接 foreach,然后 array_push 一个个的往一个数组变量里塞。这样也能实现。但这样的写法很影响性能,因为使用 PHP 原生的函数肯定比循环效率高。

    代码清单:

    [php] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. $ids = array();  
    2. $ids = array_map('array_shift', $user);  


    如上代码就可以得到我们想要的结果了,关于函数的使用想看手册。

    其实这里面还有一种方案,使用 array_column 函数,不过此函数需要 PHP 版本要求,(PHP 5 >= 5.5.0)

    代码清单:

    [php] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. $ids = array();  
    2. $ids = array_column($user, 'id');  

    这样的话,效率肯定会更高了。


    2)获取索引"name"的集合,并且保存为一个一位数组,即得到 array('张三','李四',‘王五’)

    按照,我以往的写法,还是一样的foreach,然后 array_push 一个个的往一个数组变量里塞。请看高效率的代码清单。

    代码清单:

    [php] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. $names = array();  
    2. $names = array_reduce($user, create_function('$v,$w', '$v[$w["id"]]=$w["name"];return $v;'));  


    得到结果:

    [php] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. array(  
    2.     1 => '张三',  
    3.     2 => '李四',  
    4.     5 => '王五',  
    5. );  

    经常 foreach 的童鞋,赶快更正吧!

  • 相关阅读:
    Use 'mysqld --thread_stack=#' to specify a bigger stack.
    Caused by: com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: You have an error in your SQL syntax;
    interface interface com.alibaba.dubbo.common.compiler.Compiler, class line com.alibaba.dubbo.common.compiler.support.JavassistCompiler) in
    javax.servlet.http.HttpServlet was not found on the Java Build Path
    js_jquery单机事件不起作用
    JavaScript 执行环境及作用域
    闭包的使用场景
    YUI css reset
    比较经典的数组去重和数组排序
    css 响应式布局
  • 原文地址:https://www.cnblogs.com/code81/p/4991082.html
Copyright © 2020-2023  润新知