CodeIgniter数据JSON数组转换指南

CodeIgniter数据JSON数组转换指南

本教程旨在解决codeigniter中将数据库查询结果转换为特定json数组格式的问题,特别是将键值对数据(如日期和总金额)重塑为嵌套的时间戳-数值对数组。通过详细的数据后处理和类型转换示例,指导开发者如何灵活地构建符合前端需求的json数据结构,确保输出格式精确无误。

在CodeIgniter开发中,我们经常需要从数据库中获取数据并将其以JSON格式返回给前端。然而,直接对数据库查询结果进行json_encode操作,通常会生成一个由键值对对象组成的数组,这在许多情况下是期望的。但有时,前端或API消费者可能需要一种更为精简或特定结构的数据格式,例如一个由时间戳和数值组成的嵌套数组,而非包含字段名的对象。

问题描述与常见误区

假设我们从数据库中查询到了一系列发票数据,其原始结构可能类似于:

[  {"date_issued":"2021-03-01","grand_total":"972.948"},  {"date_issued":"2021-03-12","grand_total":"1025.88"}]

我们期望将其转换为如下的JSON格式:

{  "price": [    [1483275269000, 972.948],    [1483361668000, 1025.88]  ]}

其中,date_issued被转换为Unix时间戳(通常是毫秒级,但在PHP中strtotime返回秒级,需要额外处理),grand_total被转换为浮点数。

如果直接尝试将查询结果赋值给一个数组元素并进行json_encode,例如:

$invoices = $this->invoice_model->getAllData2(logged('company_id'));$response['price'] = $invoices;echo json_encode($response);

输出结果仍然会保留原始的键值对结构:

{"price":[{"date_issued":"2021-03-01","grand_total":"972.948"},{"date_issued":"2021-03-12","grand_total":"1025.88"}]}

这显然不符合我们的目标。问题在于json_encode函数会忠实地将PHP数组或对象转换为JSON结构,它不会自动进行深层的数据重塑或类型转换。因此,在编码之前,我们需要手动对数据进行预处理。

解决方案:数据预处理与类型转换

要实现所需的JSON结构,核心在于遍历原始数据,并根据目标格式对每个数据项进行转换和重塑。

以下是实现这一目标的PHP代码示例:

 '2021-03-01', 'grand_total' => '972.948'],//     (object)['date_issued' => '2021-03-12', 'grand_total' => '1025.88']// ];// 如果模型返回的是关联数组,则数据结构为:// $invoices = [//     ['date_issued' => '2021-03-01', 'grand_total' => '972.948'],//     ['date_issued' => '2021-03-12', 'grand_total' => '1025.88']// ];// 从模型获取数据$invoices = $this->invoice_model->getAllData2(logged('company_id'));$temp = []; // 初始化一个临时数组,用于存放转换后的数据foreach ($invoices as $key1 => $value1) {    $row = []; // 为每个发票记录创建一个新的子数组    foreach ($value1 as $key2 => $value2) {        switch ($key2) {            case 'date_issued':                // 将日期字符串转换为Unix时间戳(秒),然后乘以1000得到毫秒                // 注意:strtotime返回秒级时间戳,如果前端需要毫秒级,需乘以1000                $row[] = strtotime($value2) * 1000;                break;            case 'grand_total':                // 将总金额字符串转换为浮点数                $row[] = floatval($value2);                break;            default:                // 忽略其他不需要的字段                break;        }    }    $temp[] = $row; // 将处理后的行添加到临时数组中}$response['price'] = $temp; // 将转换后的数据赋值给响应数组的'price'键echo json_encode($response); // 编码并输出JSON?>

代码解释:

$temp = [];: 创建一个空的数组$temp,它将用来存储最终转换后的数据。foreach ($invoices as $key1 => $value1): 外层循环遍历从模型中获取的每一条发票记录。$value1在每次迭代中代表一个发票对象或关联数组(如[‘date_issued’ => ‘…’, ‘grand_total’ => ‘…’])。$row = [];: 在每次处理一个新的发票记录时,初始化一个空的$row数组。这个数组将存放当前发票记录转换后的时间戳和金额。foreach ($value1 as $key2 => $value2): 内层循环遍历当前发票记录($value1)的各个字段。$key2是字段名(如date_issued),$value2是字段值。switch ($key2): 根据字段名进行条件判断,执行不同的转换逻辑。case ‘date_issued’:: 如果字段是date_issued,使用strtotime($value2)将日期字符串转换为Unix时间戳(以秒为单位)。由于许多前端库(如JavaScript的Date对象)习惯使用毫秒级时间戳,我们将其乘以1000以符合常见需求。然后,将这个时间戳添加到当前的$row数组中。case ‘grand_total’:: 如果字段是grand_total,使用floatval($value2)将其转换为浮点数类型。这是为了确保JSON中的数值类型正确,避免以字符串形式传输数字。然后,将这个浮点数添加到$row数组中。default:: 对于其他不需要的字段,可以选择忽略。$temp[] = $row;: 当一个发票记录的所有相关字段处理完毕后,将填充好的$row数组添加到$temp数组中。$response[‘price’] = $temp;: 将最终转换好的$temp数组赋值给$response数组的price键。echo json_encode($response);: 使用json_encode函数将$response数组转换为JSON字符串并输出。

注意事项与最佳实践

数据类型转换的重要性:在JSON中,数字和字符串是不同的类型。数据库中取出的数字(特别是小数)有时会被视为字符串。使用floatval()、intval()等函数进行显式类型转换非常重要,以确保JSON输出的数值类型正确。时间戳单位:PHP的strtotime()函数返回的是秒级Unix时间戳。如果前端需要毫秒级时间戳,务必将其乘以1000。灵活性:这种数据预处理方法非常灵活,可以根据任何复杂的JSON结构需求进行定制。例如,如果需要将多个字段合并为一个字符串,或者进行更复杂的计算,都可以在foreach循环中实现。性能考量:对于非常大的数据集,这种逐条遍历和转换的方式可能会有性能开销。在这种情况下,可以考虑在数据库查询阶段就进行一定程度的格式化(例如使用SQL函数),或者在PHP中利用array_map等函数进行更简洁的转换。错误处理:在实际应用中,应考虑strtotime()等函数可能返回false的情况(例如,当日期字符串格式不正确时),并添加相应的错误处理逻辑。json_encode选项:json_encode函数接受第二个参数作为选项位掩码,例如JSON_PRETTY_PRINT可以使输出的JSON更具可读性,方便调试。在生产环境中通常不使用,以减少传输大小。

总结

当CodeIgniter(或其他PHP框架)需要返回特定格式的JSON数组,而直接json_encode无法满足需求时,关键在于在编码前对数据进行精细的预处理和类型转换。通过遍历原始数据,并针对每个字段应用适当的转换逻辑(如日期转时间戳、字符串转浮点数),我们可以精确地构建出符合任何复杂前端需求的JSON数据结构。这种方法虽然需要一些额外的代码,但提供了极大的灵活性和控制力,是构建健壮API的常用实践。

以上就是CodeIgniter数据JSON数组转换指南的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1323839.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
使用PHP正则表达式从@提及字符串中提取特定标识符
上一篇 2025年12月12日 10:34:24
在Laravel中高效处理前端JS数组:实现批量数据更新的教程
下一篇 2025年12月12日 10:34:35

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    900
  • 修复Django电商项目中AJAX过滤产品列表图片不显示问题

    在Django电商项目中,当使用AJAX动态加载过滤后的产品列表时,常遇到图片无法正常显示的问题。这通常是由于前端模板中图片加载方式(如data-setbg属性结合JavaScript库)与AJAX动态内容更新机制不兼容所致。解决方案是直接在AJAX返回的HTML中使用标准的标签来渲染图片,确保浏览…

    2026年5月10日
    000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • 获取日期中的周数:CodeIgniter 教程

    本教程旨在帮助开发者在 CodeIgniter 框架中,从日期字符串中准确提取周数。我们将使用 PHP 内置的 DateTime 类,并提供详细的代码示例和注意事项,确保您能够轻松地在项目中实现此功能。 使用 DateTime 类获取周数 PHP 的 DateTime 类提供了一种便捷的方式来处理日…

    2026年5月10日
    000
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • 修复点击时按钮抖动:CSS垂直对齐实践

    本文探讨了在Web开发中,交互式按钮(如播放/暂停按钮)在点击时发生意外垂直位移的问题。通过分析CSS样式变化对元素布局的影响,我们发现这是由于按钮不同状态下的边框样式和内边距改变,以及默认的垂直对齐行为共同作用所致。核心解决方案是利用CSS的vertical-align属性,将其设置为middle…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    000
  • 前端缓存策略与JavaScript存储管理

    根据数据特性选择合适的存储方式并制定清晰的读写与清理逻辑,能显著提升前端性能;合理运用Cookie、localStorage、sessionStorage、IndexedDB及Cache API,结合缓存策略与定期清理机制,可在保证用户体验的同时避免安全与性能隐患。 前端缓存和JavaScript存…

    2026年5月10日
    100
  • HTML5网页如何实现手势操作 HTML5网页移动端交互的处理技巧

    首先利用原生touch事件实现滑动判断,再通过preventDefault解决滚动冲突,接着引入Hammer.js处理复杂手势,最后通过优化点击区域、避免事件冲突和增加视觉反馈提升体验。 在移动端浏览器中,HTML5网页可以通过触摸事件实现手势操作,提升用户体验。虽然原生JavaScript提供了基…

    2026年5月10日
    000
  • 深入理解 Express.js 中 next() 参数的作用与中间件机制

    本文深入探讨 express.js 中间件函数中的 `next()` 参数。它负责将控制权传递给请求-响应周期中的下一个中间件或路由处理程序。文章将详细解释 `next()` 的工作原理、中间件的注册与执行顺序,以及不正确使用 `next()` 可能导致请求挂起的风险,并通过代码示例和实际应用场景,…

    2026年5月10日
    000
  • PHP动态生成表单输入与POST数据获取实践指南

    本教程详细阐述了如何在php中根据动态数据源(如数据库值)生成多个表单输入框,并演示了如何通过post方法准确无误地获取这些动态生成的输入值。文章强调了正确的输入框命名策略,避免了常见的命名误区,并提供了完整的代码示例,确保开发者能够高效处理动态表单数据。 动态生成表单输入 在Web开发中,我们经常…

    2026年5月10日
    000
  • JavaScript 闭包:理解闭包原理与内存泄漏问题

    闭包是函数访问其外部作用域变量的能力,即使外部函数已执行完毕。如 inner 函数引用 outer 中的 count,形成闭包,使变量持久存在。闭包本身无害,但可能因延长变量生命周期导致内存泄漏,例如事件监听器引用大对象时。若未及时清理 DOM 事件或定时器,闭包会阻止垃圾回收,造成内存占用过高。解…

    2026年5月10日
    000
  • JavaScript 动态菜单点击高亮效果实现教程

    本教程详细介绍了如何使用 JavaScript 实现动态菜单的点击高亮功能。通过事件委托和状态管理,当用户点击菜单项时,被点击项会高亮显示(绿色),同时其他菜单项恢复默认样式(白色)。这种方法避免了不必要的DOM操作,提高了性能和代码可维护性,确保了无论点击方向如何,功能都能稳定运行。 动态菜单高亮…

    2026年5月10日
    200
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    000
  • Golang空接口如何应用在项目中

    空接口可用于接收任意类型值,常见于日志函数、通用数据结构、JSON动态解析及配置驱动逻辑,提升代码灵活性,但需配合类型断言确保安全,避免滥用以降低维护成本。 空接口 interface{} 在 Go 语言中是一个非常灵活的类型,它可以存储任何类型的值。虽然它牺牲了一部分类型安全,但在实际项目中合理使…

    2026年5月10日
    100
  • 动态更新圆形进度条:JavaScript成绩计算器集成指南

    本文档旨在指导开发者如何将JavaScript成绩计算系统与动态圆形进度条集成,实现可视化展示平均成绩。我们将详细讲解如何修改现有的JavaScript代码,使其在计算出平均分后,能够动态更新圆形进度条的进度,从而提供更直观的用户体验。本文档包含详细的代码示例和注意事项,帮助开发者轻松实现这一功能。…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信