PHP 多维数组处理利器:array_column() 用法详解

在日常 PHP 开发中,处理多维数组是非常常见的需求。例如,从数据库查询结果中提取某一列数据,或整理接口返回的嵌套数组等。array_column() 函数正是为此而生------它能用极简的代码从多维数组中提取单列值,极大简化数组操作逻辑。

一、array_column() 函数简介

  1. 函数作用

array_column() 是 PHP 5.5.0 及以上版本内置的数组函数。它的核心功能是:

  • 从一个多维数组中返回指定单列的值
  • 支持自定义返回数组的键名
  • 避免手动循环遍历数组的繁琐代码
  1. 语法结构

array_column(array <math xmlns="http://www.w3.org/1998/Math/MathML"> a r r a y , i n t ∣ s t r i n g ∣ n u l l array, int|string|null </math>array,int∣string∣nullcolumn_key, int|string|null $index_key = null): array

  • $array(必需):待处理的多维数组
  • $column_key(必需):要提取的列的键名(字符串/数字),传 null 时返回整个数组(PHP7.0+ 支持)
  • $index_key(可选):用数组中某一列的值作为返回数组的键名,让结果数组更易按键取值

二、array_column() 基础实战实例

  1. 提取多维数组的单列值
php 复制代码
 $users = [
            ['id' => 1, 'name' => '张三', 'age' => 22 ],
            ['id' => 2, 'name' => '李四', 'age' => 25 ],
            ['id' => 3, 'name' => '王五', 'age' => 28],
        ];

// 提取所有用户的姓名列
        $userNames = array_column($users, 'name');

        print_r($userNames);

输出结果:

Array ( [0] => 张三 [1] => 李四 [2] => 王五 )

三、array_column() 在 ThinkPHP6 中的应用

ThinkPHP6 是国内主流的 PHP 框架,数据库查询(Db 类/模型)返回的结果集多为数组或对象数组,array_column() 能极大简化数据处理。

  1. 从模型查询结果中提取单列值

场景:获取指定用户关联的订单 ID 集合

php 复制代码
$orderList = Order::where('user_id', 1)->select()->toArray();
$orderIds = array_column($orderList, 'id');
  1. 提取数据并定义键名,用于关联查询

场景:获取用户列表,并判断用户是否已下单

php 复制代码
// 模拟数据库查询返回的多维数组
$userList = User::select()->toArray();
$userIds = array_column($userList, 'id');

$orderList = Order::whereIn('user_id', $userIds)->select()->toArray();
$orderData = array_column($orderList, null, 'user_id');

foreach ($userList as $key => $user) {
    $user['has_order'] = (bool) ($orderData[$user['id']] ?? null);
}
  1. 处理 Db 类查询的结果集

场景:获取用户列表,并判断用户是否已下单

php 复制代码
$userList = Db::name('user')->select();
$userIds = array_column($userList, 'id');

$orderList = Db::name('order')->whereIn('user_id', $userIds)->select();
$orderData = array_column($orderList, null, 'user_id');

foreach ($userList as $key => $user) {
    $user['has_order'] = (bool) ($orderData[$user['id']] ?? null);
}
相关推荐
t198751287 小时前
使用深度神经网络解决无线网络资源分配问题的MATLAB实现
matlab·php·dnn
m0_459252468 小时前
fastadmin动态渲染统计信息
开发语言·前端·javascript·php
AI成长日志8 小时前
【实用工具教程】Linux常用命令速查与实战场景:文件操作、进程管理与网络调试高频命令解析
linux·php
ccchen8889 小时前
适配帝国CMS 8.0:全新帝国CMS免登录采集发布插件
经验分享·爬虫·php·帝国cms自动采集发布插件·帝国cms8.0·帝国cms自动采集插件·帝国cms采集发布模块
vx-程序开发11 小时前
springboot在线装修管理系统-计算机毕业设计源码56278
java·c语言·spring boot·python·spring·django·php
幽络源小助理11 小时前
网页软件库源码(带1153条资源)-含详细搭建教程
php
博语小屋13 小时前
多路转接select、poll
开发语言·网络·c++·php
xuansec13 小时前
PHP 反序列化漏洞学习笔记(CTF向总结)
笔记·学习·php
liuxin_072514 小时前
Composer 安装
php·composer
共享家952716 小时前
Java入门( 异常 )
java·开发语言·php