0

0

PHP 多维数组按 id 和 loc 键精确匹配并执行 qt 值减法运算

心靈之曲

心靈之曲

发布时间:2026-01-31 12:59:11

|

632人浏览过

|

来源于php中文网

原创

PHP 多维数组按 id 和 loc 键精确匹配并执行 qt 值减法运算

本文介绍如何在 php 中对两个含 `id` 和 `loc` 字段的多维数组进行精准匹配,对相同 `(id, loc)` 组合下的 `qt` 值执行减法运算,并保留未匹配项,最终统一标记为 `"type" => "total"`。

在实际业务中(如库存管理、出入库对账),常需将“出库(down)”与“入库(up)”数据按唯一业务键(如商品 ID + 仓库位置)对齐后计算净余量。本例中,down 数组代表原始数量,up 数组代表需扣减的数量;仅当 id 和 loc 同时相等时才执行 qt 相减,其余项保持原值并更新 type 为 "total"。

以下是推荐的健壮实现方案:

function findUpMatch(array $upArray, int $id, int $loc): ?int
{
    foreach ($upArray as $key => $item) {
        if (isset($item['id'], $item['loc']) && $item['id'] === $id && $item['loc'] === $loc) {
            return $key;
        }
    }
    return null;
}

function subtractQtByMatch(array $down, array $up): array
{
    $result = [];

    foreach ($down as $item) {
        // 必须确保关键字段存在且为整型,避免类型松散比较引发错误
        if (!isset($item['id'], $item['loc'], $item['qt'])) {
            continue; // 跳过不完整条目
        }

        $matchKey = findUpMatch($up, (int)$item['id'], (int)$item['loc']);

        if ($matchKey !== null && isset($up[$matchKey]['qt'])) {
            $qtDiff = (int)$item['qt'] - (int)$up[$matchKey]['qt'];
            // 确保结果非负?按需调整(本例允许负值,但业务中常设 max(0, $qtDiff))
            $result[] = [
                'id'   => $item['id'],
                'loc'  => $item['loc'],
                'type' => 'total',
                'qt'   => $qtDiff
            ];
        } else {
            // 无匹配项:保留原 qt,仅更新 type
            $result[] = [
                'id'   => $item['id'],
                'loc'  => $item['loc'],
                'type' => 'total',
                'qt'   => (int)$item['qt']
            ];
        }
    }

    return $result;
}

// 使用示例
$total = subtractQtByMatch($down, $up);
print_r($total);

关键优化说明

  • 使用严格比较 === 并显式类型转换((int)),避免字符串 '26' 与整数 26 比较异常;
  • findUpMatch() 返回 ?int(PHP 8.0+ 类型声明),语义清晰且利于静态分析;
  • 跳过缺失关键字段的条目,提升鲁棒性;
  • 将逻辑封装为独立函数,便于单元测试与复用;
  • 不依赖全局变量或引用传递,符合函数式编程原则。

⚠️ 注意事项

一览妙笔
一览妙笔

自媒体、编剧、营销人员写作工具

下载

立即学习PHP免费学习笔记(深入)”;

  • 若 up 数组存在重复 (id, loc) 组合,当前逻辑仅取首个匹配项。如需处理多匹配(如累计扣减),应改用 array_filter() 收集全部匹配并求和;
  • 如需保留原始 down 中未参与计算的字段(如 extra_info),请在构造 $result 项时使用 array_merge($item, [...]);
  • 对于大数据量(>1000 条),建议预先构建 $upIndex = [$id . '_' . $loc => $qt] 哈希索引,将时间复杂度从 O(n×m) 优化至 O(n+m)。

该方案简洁、可读性强,兼顾正确性与工程实践,适用于各类基于复合键的数组差分场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
视频后缀名都有哪些
视频后缀名都有哪些

视频后缀名都有avi、mpg、mpeg、rm、rmvb、flv、wmv、mov、mkv、ASF、M1V、M2V、MPE、QT、VOB、RA、RMJ、RMS、RAM、等等。更多关于视频后缀名的相关知识,详情请看本专题下面的文章,php中文网欢迎大家前来学习。

3912

2023.10.31

C++ Qt图形开发
C++ Qt图形开发

本专题专注于 C++ Qt框架在图形界面开发中的应用,系统讲解窗口设计、信号与槽机制、界面布局、事件处理、数据库连接与跨平台打包等核心技能,通过多个桌面应用项目实战,帮助学员快速掌握 Qt 框架并独立完成跨平台GUI软件的开发。

76

2025.08.15

C++ 图形界面开发基础(Qt方向)
C++ 图形界面开发基础(Qt方向)

本专题系统讲解 使用 C++ 与 Qt 进行图形界面(GUI)开发的核心技能,内容涵盖 Qt 项目结构、窗口组件、信号与槽机制、事件处理、布局管理、资源管理,以及跨平台编译与打包流程。通过多个小型桌面应用实战案例,帮助学习者掌握从界面设计到功能实现的完整 GUI 开发能力。

112

2025.12.05

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

103

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

127

2025.09.18

c++ 全局变量
c++ 全局变量

本专题整合了c++全局变量的使用、定义、作用域等等内容,阅读专题下面的文章了解更多详细内容。

3

2026.03.17

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

781

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号