0

0

CodeIgniter中将关联数组转换为特定格式的JSON数组

花韻仙語

花韻仙語

发布时间:2025-10-14 13:24:07

|

556人浏览过

|

来源于php中文网

原创

CodeIgniter中将关联数组转换为特定格式的JSON数组

本文详细介绍了在codeigniter框架中,如何将从数据库获取的关联数组数据,通过编程转换成前端所需的特定嵌套json数组格式。核心在于对原始数据进行迭代处理,将日期字符串转换为unix时间戳,并将数字字符串转换为浮点数,最终构建出符合目标结构的数组,再进行json编码输出。

在Web开发中,我们经常需要将后端获取的数据以特定的JSON格式返回给前端。CodeIgniter作为一款流行的PHP框架,其数据处理和输出能力强大,但有时数据库返回的原始数据结构与前端期望的JSON结构并不完全一致,尤其是在涉及数据类型转换和数组嵌套时。本文将探讨如何将一个包含日期和总金额的关联数组,转换成一个嵌套的、包含Unix时间戳和浮点数值的JSON数组。

理解问题:原始数据与目标格式的差异

假设我们从CodeIgniter的模型中获取到如下形式的关联数组数据,通常这是数据库查询结果的直接映射:

// $invoices 变量的示例内容
[
    [
        "date_issued" => "2021-03-01",
        "grand_total" => "972.948"
    ],
    [
        "date_issued" => "2021-03-12",
        "grand_total" => "1025.88"
    ]
]

当直接使用 json_encode($invoices) 并将其赋值给一个键(例如 price)时,我们得到的是:

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

然而,前端可能期望的格式是这样的,它是一个嵌套数组,其中每个内部数组包含一个Unix时间戳(毫秒级)和一个浮点数:

{
  "price": [
    [
      1483275269000, // Unix时间戳,通常是秒级,这里示例是毫秒级
      972.948
    ],
    [
      1483361668000,
      1025.88
    ]
  ]
}

显而易见,主要差异在于:

  1. 原始数据是关联数组,目标是索引数组(嵌套)。
  2. date_issued 是日期字符串,目标是Unix时间戳(数字)。
  3. grand_total 是字符串形式的数字,目标是浮点数。

解决方案:数据转换与重构

要实现这种转换,我们需要对从模型获取的原始数据进行迭代处理,并根据目标格式重构数据。以下是在CodeIgniter控制器中实现此转换的步骤和示例代码:

AI神器大全
AI神器大全

AI工具集合导航站

下载

首先,从模型获取原始数据:

$invoices = $this->invoice_model->getAllData2(logged('company_id'));

接下来,对 $invoices 数组进行遍历和转换:

$temp = []; // 初始化一个临时数组,用于存储转换后的数据

foreach($invoices as $key1 => $value1) {
    // 对于每个发票记录(例如 $value1 = ["date_issued" => "...", "grand_total" => "..."])
    foreach($value1 as $key2 => $value2) {    
        switch($key2) {
            case 'date_issued':
                // 将日期字符串转换为Unix时间戳。
                // strtotime() 返回的是秒级时间戳,如果前端需要毫秒级,需要乘以1000。
                $temp[$key1][] = strtotime($value2) * 1000; // 乘以1000转换为毫秒
            break;
            case 'grand_total':
                // 将字符串形式的数字转换为浮点数。
                $temp[$key1][] = floatval($value2);
            break;
            default:
                // 如果有其他字段不需要转换或需要保留,可以在这里处理。
                // 对于本例,我们只关心这两个字段。
            break;
        }
    }
}

// 将转换后的数据赋值给响应数组的 'price' 键
$response['price'] = $temp;

// 使用 json_encode 输出JSON。TRUE 参数在旧版CodeIgniter中可能用于美化输出,
// 但在PHP的json_encode函数中,第二个参数是选项位掩码,通常用于JSON_PRETTY_PRINT等。
// 直接使用 json_encode($response) 即可。
echo json_encode($response);

完整控制器代码示例

将上述逻辑整合到CodeIgniter的控制器方法中,可能看起来像这样:

load->model('invoice_model'); // 确保加载了你的模型
    }

    public function getInvoicePrices() {
        // 假设 logged('company_id') 获取当前登录用户的公司ID
        $companyId = logged('company_id'); 

        // 从模型获取原始发票数据
        $invoices = $this->invoice_model->getAllData2($companyId);

        $temp = []; // 初始化临时数组

        // 遍历原始数据并进行转换
        foreach($invoices as $invoice) {
            $timestamp = strtotime($invoice['date_issued']) * 1000; // 转换为毫秒级时间戳
            $grandTotal = floatval($invoice['grand_total']); // 转换为浮点数

            // 构建新的嵌套数组元素
            $temp[] = [$timestamp, $grandTotal];
        }

        // 将转换后的数据赋值给响应数组
        $response['price'] = $temp;

        // 设置响应头为JSON
        $this->output
             ->set_content_type('application/json')
             ->set_output(json_encode($response));
    }
}

注意事项:

  1. 时间戳精度: strtotime() 函数返回的是Unix时间戳(秒)。如果前端期望的是毫秒级时间戳,请务必将其乘以 1000。
  2. 数据类型转换: floatval() 和 strtotime() 是PHP中进行数据类型转换的常用函数。确保原始数据格式与这些函数的预期输入兼容。
  3. 错误处理: 在实际应用中,应考虑对 strtotime() 可能返回 false(无效日期)的情况进行处理,以避免生成不正确的数据。
  4. 优化循环: 上述示例中的嵌套 foreach 循环和 switch 语句是有效的,但如果字段数量固定且已知,可以直接访问字段名,如第二个完整示例所示,这通常更简洁高效。
  5. CodeIgniter输出: 使用 $this->output->set_content_type('application/json')->set_output(json_encode($response)); 是CodeIgniter推荐的输出JSON的方式,它会自动设置正确的HTTP头。

总结

将后端数据转换为前端所需的特定JSON格式是常见的开发任务。通过对原始数据进行迭代处理、精确的数据类型转换(如日期到时间戳、字符串到浮点数)以及数组结构的重构,我们可以灵活地满足各种前端需求。理解原始数据和目标格式之间的差异,并选择合适的PHP函数进行转换,是实现这一目标的关键。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

418

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

308

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

537

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

422

2024.03.13

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

9

2026.01.27

热门下载

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

精品课程

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

共137课时 | 9.7万人学习

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号