如何从嵌套 JSON 响应中构建结构化数组并按尺寸顺序排序
发布时间 - 2026-01-08 00:00:00 点击率:次本文详解如何将原始 json 中的水果、总量及多维尺寸关联数据,重组为按水果分组、含总量与有序尺寸子数组的新结构,并确保 `size` 字段严格按数值逻辑升序排列(如 "100-500" → "5000-10,000" → "10,001+")。
在实际数据可视化或表格渲染场景中,原始 API 返回的扁平化嵌套结构(如 SizeAndFruit)往往难以直接用于 UI 展示。本教程以 PHP 为例,提供一套清晰、可复用的转换逻辑,将杂乱关联数据重构为面向视图的层级数组。
✅ 核心步骤概览
- 初始化基础结构:遍历 fruits 数组,为每种水果创建含 name 和 totalResults 的骨架;
- 填充尺寸明细:遍历 SizeAndFruit,按 name 匹配并追加 {size, pieces} 到对应水果的 sortedResults;
- 关键排序处理:定义 sizeStringToNumber() 映射函数,将语义化尺寸字符串(如 "10,001+ eaters")映射为可比较的整数基准值;
- 稳定排序:对每个水果的 sortedResults 使用 usort() 按映射后的数值升序排列,避免字典序错乱(如 "10,001+"
? 完整可运行代码(PHP)
fruits as $fruit) {
$out[] = [
'name' => $fruit->name,
'totalResults' => $fruit->pieces,
'sortedResults' => [],
];
}
// 步骤2:注入 SizeAndFruit 数据
foreach ($inputJson->SizeAndFruit as $entry) {
$newEntry = ['size' => $entry->size, 'pieces' => $entry->pieces];
foreach ($out as &$fruit) {
if ($fruit['name'] === $entry->name) {
$fruit['sortedResults'][] = $newEntry;
}
}
}
// 步骤3+4:定义尺寸映射与排序逻辑
function sizeStringToNumber(string $size): int {
$map = [
'100-500 eaters' => 100,
'5000-10,000 eaters' => 5000,
'10,001+ eaters' => 10001, // 注意:此处用 10001 更符合“10,001+”语义,避免与 10000 混淆
];
return $map[$size] ?? throw new InvalidArgumentException("Unknown size format: {$size}");
}
// 对每个水果的 sortedResults 进行数值排序
foreach ($out as &$fruit) {
usort($fruit['sortedResults'], function ($a, $b) {
return sizeStringToNumber($a['size']) <=> sizeStringToNu
mber($b['size']);
});
}
// 封装最终输出
$result = ['newArray' => $out];
echo json_encode($result, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
⚠️ 注意事项与最佳实践
- 健壮性增强:生产代码中应添加 json_last_error() 检查、空值判断(如 $inputJson->fruits 是否为数组)、以及 SizeAndFruit 条目缺失时的兜底逻辑;
- 尺寸映射可扩展:若未来新增尺寸类型(如 "10-100 eaters"),只需更新 $map 数组,无需修改排序逻辑;
- 性能优化提示:当 SizeAndFruit 数据量极大时,可预先构建 name → [entries] 的哈希表,将时间复杂度从 O(n×m) 降至 O(n+m);
- 前端兼容性:生成的 JSON 可直接被 JavaScript fetch() 解析,配合 map() 渲染表格行,每行对应一个 newArray[i]。
通过此方案,你不仅能精准生成目标结构,更获得了一套可维护、易扩展的数据规整范式——让复杂关联数据真正服务于清晰的业务呈现。
# php
# javascript
# java
# js
# 前端
# json
# 数据可视化
# 排列
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
开心动漫网站制作软件下载,十分开心动画为何停播?
如何快速重置建站主机并恢复默认配置?
如何快速上传自定义模板至建站之星?
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
如何快速搭建二级域名独立网站?
用yum安装MySQLdb模块的步骤方法
大同网页,大同瑞慈医院官网?
Android使用GridView实现日历的简单功能
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
js实现点击每个li节点,都弹出其文本值及修改
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
如何用好域名打造高点击率的自主建站?
如何快速打造个性化非模板自助建站?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
EditPlus 正则表达式 实战(3)
详解CentOS6.5 安装 MySQL5.1.71的方法
Laravel如何实现事件和监听器?(Event & Listener实战)
做企业网站制作流程,企业网站制作基本流程有哪些?
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
LinuxShell函数封装方法_脚本复用设计思路【教程】
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
EditPlus中的正则表达式实战(6)
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】
实现点击下箭头变上箭头来回切换的两种方法【推荐】
如何快速查询网址的建站时间与历史轨迹?
Laravel如何创建自定义Artisan命令?(代码示例)
夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化
Laravel distinct去重查询_Laravel Eloquent去重方法
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
油猴 教程,油猴搜脚本为什么会网页无法显示?
Python图片处理进阶教程_Pillow滤镜与图像增强
如何在建站主机中优化服务器配置?
Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道
七夕网站制作视频,七夕大促活动怎么报名?
如何撰写建站申请书?关键要点有哪些?
如何注册花生壳免费域名并搭建个人网站?
Python并发异常传播_错误处理解析【教程】
利用 Google AI 进行 YouTube 视频 SEO 描述优化
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
网站制作企业,网站的banner和导航栏是指什么?
Laravel如何处理异常和错误?(Handler示例)
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
实例解析angularjs的filter过滤器
上一篇:linux怎么查询时区
上一篇:linux怎么查询时区


mber($b['size']);
});
}
// 封装最终输出
$result = ['newArray' => $out];
echo json_encode($result, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);