• PHP 将二维数组中某列值作为数组的键名 -- 超实用


    有时候,想通过数组的中某字段值, 然后再在二维数组中获取存在该字段值的数组;

    一般能想到的就是foreach 遍历比较一下跟该字段值一样,就获取到想要的数组,如下:

    // 测试二维数组                                         
    $arr = array (                                    
      0 =>  array (                                  
        'value' => 1,                          
        'name' => 'test_0',                    
      ),                                       
      1 => array (                                  
        'value' => 2,                          
        'name' => 'test_1',                    
      ),                                       
      2 => array (                                  
        'value' => 3,                          
        'name' => 'test_2',                    
      ),                                       
      3 => array (                                  
        'value' => 4,                          
        'name' => 'test_3',                    
      ),                                       
      4 => array (                                  
        'value' => 5,                          
        'name' => 'test_4',                    
      ),                                       
    );

    1. foreach 遍历大法

    比如:根据value = 4, 获取测试二维数组中value = 4的数组

    $value = 4;
    foreach ($arr as $key => $item) {
       if ($item['value'] == $value) {
           $res = $item;
       }
    }
    
    // 结果
    array (
     'value' => 4,
      'name' => 'test_3',
    )

    思考了下,要是不foreach ,直接通过二维数组的下标获取到想要的数组元素那就最好了!那要怎么样将二维数组中的元素的某个字段值变为二维数组的下标键名呢?

    so 了一下 PHP官方文档:https://www.php.net/manual/zh/function.array-column.php ,可以看到 有一个 array_column()

    array_column — 返回数组中指定的一列
    
    说明
    array_column ( array $input , mixed $column_key [, mixed $index_key = null ] ) : array
    array_column() 返回input数组中键值为column_key的列, 如果指定了可选参数index_key,那么input数组中的这一列的值将作为返回数组中对应值的键。
    
    参数
    input
    需要取出数组列的多维数组。 如果提供的是包含一组对象的数组,只有 public 属性会被直接取出。 为了也能取出 privateprotected 属性,类必须实现 __get() 和 __isset() 魔术方法。
    
    column_key
    需要返回值的列,它可以是索引数组的列索引,或者是关联数组的列的键,也可以是属性名。 也可以是NULL,此时将返回整个数组(配合index_key参数来重置数组键的时候,非常管用)
    
    index_key
    作为返回数组的索引/键的列,它可以是该列的整数索引,或者字符串键值。

    就是红色字体部分说到了,实践见证奇迹!!!

    2. array_column() 大大法

    $tempArr = array_column($arr, null, 'value');

    结果:

    // 以value字段为键名                                      
    array (                                  
      1 => array (                                
        'value' => 1,                        
        'name' => 'test_0',                  
      ),
     2 => array (                                
        'value' => 2,                        
        'name' => 'test_1',                  
      ),                                     
      3 => array (                                
        'value' => 3,                        
        'name' => 'test_2',                  
      ),                                     
      4 => array (                                
        'value' => 4,                        
        'name' => 'test_3',                  
      ),                                     
      5 => array (                                
        'value' => 5,                        
        'name' => 'test_4',                  
      ),                                     
    )  
     // 以name字段为键名   
    $tempArr = array_column($arr, null, 'name');
    array (     'test_0' => array (       'value' => 1,       'name' => 'test_0',     ),     'test_1' => array (       'value' => 2,       'name' => 'test_1',     ),     'test_2' => array (       'value' => 3,       'name' => 'test_2',     ),     'test_3' => array (       'value' => 4,       'name' => 'test_3',     ),     'test_4' => array (       'value' => 5,       'name' => 'test_4',     ), )

     然后,这样就可以直接通过 某个字段值 获取到二维数组中 某字段值 的数组元素了!超实用!!!

    // 实用数组下标方式获取想要数组元素
    $res = $tempArr[$value];
    // 结果
    array (
     'value' => 4,
      'name' => 'test_3',
    )

    案例:

    $pageGoods =  DB::table($orderGoodsTable." as a")
                ->whereIn('order_id', $pageOrderIds)
                ->join($goodsTable." as b", "b.goods_id", "=", "a.goods_id")
                ->select("a.order_id", "b.goods_id", "b.original_img", "b.goods_name")
                ->get()
                ->toArray();
            dd(array_column($pageGoods, null, 'order_id'));
  • 相关阅读:
    Qt中将QTableView中的数据导出为Excel文件
    QTableView另类打印解决方案(复用render函数去解决print问题)
    [网络]_[批量下载网站文件]
    Codecs是以plugin的形式被调用的(显示中文的codec plugin文件是qcncodecs4.dll),可静态载入和动态载入
    Qt的Model/View Framework解析(数据是从真正的“肉(raw)”里取得,Model提供肉,所以读写文件、操作数据库、网络通讯等一系列与数据打交道的工作就在model中做了)
    MinGW 编译zlib、libpng、libjpeg、libcurl等(全都是Qt项目)
    Move WriteBuffer ReadBuffer String
    Delphi调试DLL 不能调试 不能进入调试 注意!!!
    ssh三大框架,三层架构 整合测试!完整分页代码,JdbcTemplate等测试,存储过程调用,留着以后复习吧
    Delphi 的动态数组
  • 原文地址:https://www.cnblogs.com/jiangxiaobo/p/13603053.html
Copyright © 2020-2023  润新知