本文介绍如何将第三方 api 返回的扁平化 faq 数据(每个问答分属独立数组项)按逻辑配对,合并为结构清晰的键值对或对象数组,适用于 wordpress 自定义字段等场景。
在处理来自不可控第三方 API 的 FAQ 数据时,常见模式是:
同一组问答(如 faq_list_0_question 和 faq_list_0_answer)被拆分为两个独立数组元素,仅通过 meta_key 的命名规则隐含关联关系。此时,我们需要基于 meta_key 的语义结构(如下划线分隔的序号与类型)进行智能分组与合并。
核心思路是:提取每条记录中标识“组别”和“类型”的关键信息,以组别为键、类型为子键,动态构建嵌套结构。以下是两种常用且实用的实现方式:
适用于需保留 id、post_id 等元信息的场景:
$new_data = [];
foreach ($array['data'] as $item) {
// 拆分 meta_key,例如 "faq_list_0_question" → ['faq', 'list', '0', 'question']
$parts = explode('_', $item['meta_key']);
// 最后一部分是类型(question/answer),倒数第二部分通常是序号(如 '0')
$type = array_pop($parts);
$index = array_pop($parts); // 获取序号,如 '0'
// 重构组键,如 "faq_list_0"
$groupKey = implode('_', $parts) . '_' . $index;
// 初始化组(若不存在),并存入对应类型的数据
if (!isset($new_data[$groupKey])) {
$new_data[$groupKey] = [];
}
$new_data[$groupKey][$type] = $item;
}
// 输出示例(关联数组):
// [
// "faq_list_0" => [
// "question" => [...],
// "answer" => [...]
// ]
// ]更贴近实际业务需求——输出简洁的 FAQ 列表,每项含 id、question、answer 字段:
$new_data = [];
foreach ($array['data'] as $item) {
$parts = explode('_', $item['meta_key']);
$type = array_pop($parts); // 'question' or 'answer'
$index = array_pop($parts); // 如 '0', '1', '2'
// 确保该序号对应的 FAQ 条目已初始化
if (!isset($new_data[$index])) {
$new_data[$index] = [
'id' => $index,
'question' => '',
'answer' => ''
];
}
// 根据 type 填充内容(只取 meta_value,更符合展示需求)
if ($type === 'question') {
$new_data[$index]['question'] = $item['meta_value'];
} elseif ($type === 'answer') {
$new_data[$index]['answer'] = $item['meta_value'];
}
}
// 转为数值索引数组,确保顺序一致
$faqs = array_values($new_data);
// 输出示例(JSON 可用格式):
// [
// {
// "id": "0",
// "question": "Lorem ipsum...",
// "answer": "In at neque..."
// }
// ]通过以上方法,你无需修改上游 API,即可将松散的元数据高效转化为语义明确、易于消费的 FAQ 结构,显著提升前后端协作效率与代码可维护性。
# php
# word
# js
# 前端
# json
# wordpress
# 后端
# 键值对
# if
# count
# continue
# 数据结构
# 对象
相关文章:
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
如何配置FTP站点权限与安全设置?
无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?
小建面朝正北,A点实际方位是否存在偏差?
如何高效完成自助建站业务培训?
如何设置并定期更换建站之星安全管理员密码?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
建站之星如何快速解决建站难题?
建站VPS推荐:2025年高性能服务器配置指南
定制建站模板如何实现SEO优化与智能系统配置?18字教程
如何通过网站建站时间优化SEO与用户体验?
如何选择可靠的免备案建站服务器?
XML的“混合内容”是什么 怎么用DTD或XSD定义
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
淘宝制作网站有哪些,淘宝网官网主页?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
如何快速搭建支持数据库操作的智能建站平台?
如何快速上传建站程序避免常见错误?
沈阳制作网站公司排名,沈阳装饰协会官方网站?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
如何高效利用200m空间完成建站?
建站之星如何配置系统实现高效建站?
制作网页的网站有哪些,电脑上怎么做网页?
行程制作网站有哪些,第三方机票电子行程单怎么开?
南京网站制作费用,南京远驱官方网站?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
专业网站建设制作报价,网页设计制作要考什么证?
MySQL查询结果复制到新表的方法(更新、插入)
建站之星如何助力网站排名飙升?揭秘高效技巧
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何有效防御Web建站篡改攻击?
青岛网站建设如何选择本地服务器?
平台云上自助建站如何快速打造专业网站?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
网站制作话术技巧,网站推广做的好怎么话术?
大同网页,大同瑞慈医院官网?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
如何通过智能用户系统一键生成高效建站方案?
如何在腾讯云服务器上快速搭建个人网站?
网站制作免费,什么网站能看正片电影?
如何用好域名打造高点击率的自主建站?
C++时间戳转换成日期时间的步骤和示例代码
制作旅游网站html,怎样注册旅游网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。