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+ 类型声明),语义清晰且利于静态分析;
  • 跳过缺失关键字段的条目,提升鲁棒性;
  • 将逻辑封装为独立函数,便于单元测试与复用;
  • 不依赖全局变量或引用传递,符合函数式编程原则。

⚠️ 注意事项

Build AI
Build AI

为您的业务构建自己的AI应用程序。不需要任何技术技能。

下载

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

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

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

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能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中文网欢迎大家前来学习。

3549

2023.10.31

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

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

69

2025.08.15

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

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

79

2025.12.05

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

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

82

2025.09.18

python 全局变量
python 全局变量

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

96

2025.09.18

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

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

320

2023.08.03

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

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

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1503

2023.10.24

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

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

精品课程

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

共137课时 | 10.5万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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