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才能让你更灵活,不过优先使用系统函数总是首选的。
分类:
PHP&mysql
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程
2016-09-21 php 链接 sqlserver 2005以上版本数据库