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控制器中实现此转换的步骤和示例代码:

ToonMe
ToonMe

一款风靡Instagram的软件,一键生成卡通头像

下载

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

$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函数进行转换,是实现这一目标的关键。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2687

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1661

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1522

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

953

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

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

精品课程

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

共137课时 | 8.9万人学习

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

共6课时 | 8.5万人学习

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

共13课时 | 0.9万人学习

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

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