PHP 中合并数组数据,构建企业月度收入报表

PHP 中合并数组数据,构建企业月度收入报表

本文旨在指导开发者如何利用 php 将从数据库查询到的企业名称和月度收入数据进行有效合并,最终构建出一个易于使用和展示的企业月度收入报表数据结构。通过示例代码和详细步骤,你将学会如何将分散的数据整理成结构化的数组,方便后续的数据分析和可视化。

数据结构设计

在开始编写代码之前,清晰的数据结构至关重要。目标是创建一个数组,其中每个元素代表一个公司,每个公司包含公司名称和以日期为键的月度收入数据。

期望的数据结构如下:

[    {      "empresa": "Empresa Ejemplo 1",      "2021-02-05": 781595.14,      "2021-03-05": 345094.65,      "2021-04-09": 166694.76,      "2021-05-26": 155874.65,      "2021-06-04": 159801.81,      "2021-07-02": 161689.9    },    {      "empresa": "Empresa Ejemplo 2",      "2021-02-05": 781595.14,      "2021-03-05": 345094.65,      "2021-04-09": 166694.76,      "2021-05-26": 155874.65,      "2021-06-04": 159801.81,      "2021-07-02": 161689.9    } ]

代码实现

以下 PHP 代码示例展示了如何将从数据库查询到的数据转换成目标数据结构。

立即学习PHP免费学习笔记(深入)”;

<?php  // 模拟从数据库获取的数据 $data = [     [         'fecha' => '2021-01-08',         'ingresosTotal' => '158181.17',     ],     [         'fecha' => '2021-02-05',         'ingresosTotal' => '781595.14',     ],     [         'fecha' => '2021-03-05',         'ingresosTotal' => '345094.65',     ],     [         'fecha' => '2021-04-09',         'ingresosTotal' => '166694.76',     ],     [         'fecha' => '2021-05-26',         'ingresosTotal' => '155874.65',     ],     [         'fecha' => '2021-06-04',         'ingresosTotal' => '159801.81',     ],     [         'fecha' => '2021-07-02',         'ingresosTotal' => '161689.9',     ], ];  $empresa = 'Empresa Ejemplo 1';  $fechas = []; $fechas['empresa'] = $empresa;  foreach ($data as $value) {     $fecha = date("Y-m-d", strtotime($value['fecha'])); // 格式化日期     $fechas[$fecha] = $value['ingresosTotal']; }  echo json_encode($fechas, JSON_PRETTY_PRINT);  ?>

代码解释:

  1. 数据模拟: $data 模拟了从数据库查询到的结果集,包含日期 fecha 和收入总额 ingresosTotal。
  2. 初始化数组: 创建 $fechas 数组,并将公司名称赋值给键 empresa。
  3. 循环遍历: 使用 foreach 循环遍历 $data 数组,提取日期和收入数据。
  4. 日期格式化: 使用 date(“Y-m-d”, strtotime($value[‘fecha’])) 将日期格式化为 yyYY-MM-DD 格式。这是关键一步,确保日期格式与目标数据结构一致。 如果只需要月份,可以使用strftime(“%B”, strtotime( $value[‘fecha’] ))
  5. 数据赋值: 将格式化后的日期作为键,收入总额作为值,赋值给 $fechas 数组。
  6. JSON 编码: 使用 json_encode($fechas, JSON_PRETTY_PRINT) 将数组编码为 JSON 格式,方便查看和使用。JSON_PRETTY_PRINT 参数用于格式化 JSON 输出,使其更易于阅读。

注意事项

  • 日期格式: 确保日期格式与你的需求一致。可以使用 date() 函数进行格式化。
  • 数据类型 数据库查询结果中的数据类型可能需要转换。例如,将字符串类型的数字转换为浮点数。
  • 错误处理: 在实际应用中,需要添加错误处理机制,例如检查数据库查询是否成功,以及处理可能出现的异常情况。

总结

通过本文,你学习了如何使用 PHP 将从数据库查询到的企业名称和月度收入数据进行合并,并构建成一个结构化的数组。这个数组可以方便地用于生成企业月度收入报表,进行数据分析和可视化。 关键在于理解目标数据结构,并使用合适的 PHP 函数进行数据转换和格式化。

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享