-
PHP中array_map与array_column之间的关系分析
这篇文章主要介绍了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对应的值。
示例代码一:
- $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才能让你更灵活,不过优先使用系统函数总是首选的。
出处:http://www.phpfensi.com/php/20210405/14097.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式