0

0

PHP 处理 JSON:按日期字段分组统计每月数据

碧海醫心

碧海醫心

发布时间:2025-09-27 09:20:33

|

476人浏览过

|

来源于php中文网

原创

PHP 处理 JSON:按日期字段分组统计每月数据

本教程旨在指导如何使用 PHP 有效地解析 JSON 格式的数据,并根据其中的日期字段(如 Start_Date)进行筛选和统计,最终按月份聚合数据量。文章将涵盖 JSON 解码、数据遍历、日期格式转换及高效计数的核心步骤,帮助开发者从复杂的 JSON 结构中提取并汇总所需信息。

1. 理解 JSON 数据结构

在处理从 api 或其他源获取的 json 数据时,首先需要明确其内部结构。本教程使用的 json 示例如下,其中核心业务数据嵌套在 response.data 路径下。data 数组包含多个记录项,每项通过 fielddata 对象存储具体字段,而 start_date 则是我们进行统计的日期字段。

{
    "response": {
        "dataInfo": {
            "foundCount": 494,
            "returnedCount": 4
        },
        "data": [
            {
                "fieldData": {
                    "Closed_Date": "10/03/2021",
                    "Start_Date": "10/03/2021"
                },
                "portalData": {},
                "recordId": "152962",
                "modId": "3"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/14/2021",
                    "Start_Date": "11/06/2021"
                },
                "portalData": {},
                "recordId": "153228",
                "modId": "22"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/07/2021",
                    "Start_Date": "11/06/2021"
                },
                "portalData": {},
                "recordId": "153329",
                "modId": "7"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/08/2021",
                    "Start_Date": "11/08/2021"
                },
                "portalData": {},
                "recordId": "153513",
                "modId": "3"
            }
        ]
    },
    "messages": [
        {
            "code": "0",
            "message": "OK"
        }
    ]
}

我们的任务是遍历 data 数组中的每一条记录,提取 fieldData.Start_Date 的月份信息,并计算每个月份对应的记录数量。

2. PHP 解析 JSON 数据

在 PHP 中,json_decode() 函数是处理 JSON 数据的核心。它能将 JSON 格式的字符串转换成 PHP 可操作的数据类型,通常是对象或关联数组。为了方便后续的数据访问,我们通常将其解码为关联数组。

<?php

// 假设 $jsonString 变量已包含上述 JSON 数据
$jsonString = '{ ... }'; // 实际应用中会从文件、网络请求等获取

// 使用 json_decode 将 JSON 字符串解码为 PHP 关联数组
// 第二个参数设置为 true,表示解码为关联数组
$decodedData = json_decode($jsonString, true);

// 重要的错误检查:验证 JSON 解码是否成功
if (json_last_error() !== JSON_ERROR_NONE) {
    die("JSON 解码失败: " . json_last_error_msg());
}

// 此时 $decodedData 变量是一个 PHP 关联数组,可以通过键名访问数据
// 例如:$decodedData['response']['data']
?>

解码成功后,您可以像操作普通 PHP 数组一样访问 JSON 数据中的各个部分。

3. 按月份统计数据

统计过程包括初始化计数器、遍历数据、提取日期信息并进行累加。

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

3.1 初始化月份计数器

在开始遍历数据之前,我们需要创建一个空的关联数组,用于存储每个月份的统计结果。该数组的键将是月份(例如 "10" 代表十月,"11" 代表十一月),而值将是对应月份的记录总数。

吉卜力风格图片在线生成
吉卜力风格图片在线生成

将图片转换为吉卜力艺术风格的作品

下载
$monthCounts = []; // 用于存储最终按月份统计的结果

3.2 遍历数据并提取月份信息

接下来,我们将遍历 $decodedData['response']['data'] 数组中的每一条记录。对于每条记录,我们将执行以下步骤:

  1. 获取 Start_Date 字符串:从当前记录的 fieldData 字段中提取 Start_Date 的值。
  2. 日期字符串转 Unix 时间戳:使用 PHP 内置的 strtotime() 函数将 Start_Date 字符串(例如 "10/03/2021")转换为 Unix 时间戳。strtotime() 能够智能识别多种日期时间格式。
  3. 时间戳转月份:利用 date("m", ...) 函数,从上一步获取的 Unix 时间戳中提取两位数的月份字符串(例如 "10" 或 "11")。
  4. 累加计数:检查 $monthCounts 数组中是否已经存在该月份的键。如果不存在,则将其初始化为 0;然后,将该月份的计数器值加 1。

3.3 完整示例代码

以下是实现上述逻辑的完整 PHP 代码:

<?php

// 模拟从 API 获取的 JSON 字符串
$jsonString = '{
    "response": {
        "dataInfo": {
            "foundCount": 494,
            "returnedCount": 4
        },
        "data": [
            {
                "fieldData": {
                    "Closed_Date": "10/03/2021",
                    "Start_Date": "10/03/2021"
                },
                "portalData": {},
                "recordId": "152962",
                "modId": "3"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/14/2021",
                    "Start_Date": "11/06/2021"
                },
                "portalData": {},
                "recordId": "153228",
                "modId": "22"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/07/2021",
                    "Start_Date": "11/06/2021"
                },
                "portalData": {},
                "recordId": "153329",
                "modId": "7"
            },
            {
                "fieldData": {
                    "Closed_Date": "11/08/2021",
                    "Start_Date": "11/08/2021"
                },
                "portalData": {},
                "recordId": "153513",
                "modId": "3"
            }
        ]
    },
    "messages": [
        {
            "code": "0",
            "message": "OK"
        }
    ]
}';

// 1. 解码 JSON 字符串
$decodedData = json_decode($jsonString, true);

// 重要的错误检查:验证 JSON 解码是否成功以及关键数据结构是否存在
if (json_last_error() !== JSON_ERROR_NONE || !isset($decodedData['response']['data'])) {
    die("JSON 解码失败或数据结构不符合预期: " . json_last_error_msg());
}

// 2. 初始化月份计数器
$monthCounts = [];

// 3. 遍历数据并统计
$items = $decodedData['response']['data'];
foreach ($items as $item) {
    // 确保 'fieldData' 和 'Start_Date' 字段存在,防止因数据缺失导致错误
    if (isset($item['fieldData']['Start_Date'])) {
        $startDateString = $item['fieldData']['Start_Date'];

        // 将日期字符串转换为 Unix 时间戳
        $timestamp = strtotime($startDateString);

        // 检查日期转换是否成功,因为 strtotime() 可能会返回 false
        if ($timestamp !== false) {
            // 从时间戳中提取月份(两位数格式,如 "01", "10", "11")
            $month = date("m", $timestamp);

            // 如果该月份尚未在 $monthCounts 中,则初始化为 0
            if (!isset($monthCounts[$month])) {
                $monthCounts[$month] = 0;
            }
            // 增加该月份的计数
            $monthCounts[$month]++;
        } else {
            // 记录或处理无法解析的日期字符串
            error_log("警告:无法解析日期字符串: " . $startDateString);
        }
    } else {
        // 记录或处理缺少关键字段的数据项
        error_log("警告:数据项中缺少 'fieldData.Start_Date' 字段");
    }
}

// 4. 输出统计结果
echo "<pre>";
print_r($monthCounts);
echo "</pre>";

?>

4. 结果输出与验证

执行上述 PHP 代码后,您将获得一个关联数组作为输出,其中键是月份,值是该月份对应的记录数量。对于本教程提供的示例 JSON 数据,预期的输出将是:

Array
(
    [10] => 1
    [11] => 3
)

这个结果清晰地表明,在原始数据中,10 月份有一条记录,而 11 月份有三条记录,与我们的统计目标完全一致。

5. 注意事项与总结

  • 日期格式的鲁棒性: strtotime() 函数在处理多种日期格式方面表现出色,但对于非常规或不明确的日期格式,其解析结果可能不准确。如果 Start_Date 的格式变化多端或较为复杂,建议使用 DateTime::createFromFormat() 函数进行更精确和严格的日期解析,以确保数据的准确性。
  • 全面的错误处理: 在生产环境中,健壮性至关重要。务必对 json_decode() 的返回值进行 json_last_error() 检查,对 strtotime() 的返回值进行 false 检查,并对数组键的存在性(例如 isset($item['fieldData']['Start_Date']))进行验证。这些检查有助于防止因数据异常或缺失而导致的程序崩溃。
  • 性能考量: 对于包含海量记录的 JSON 数据,循环遍历可能会带来一定的性能开销。然而,对于大多数常见规模的数据集,上述方法已经足够高效。如果面临极端大数据量的场景,可以考虑采用更优化的数据处理策略或使用专门的数据处理库。
  • 统计维度的扩展: 本教程展示了按月份统计的方法。如果您需要按年份、季度、周或更复杂的日期范围进行统计,只需调整 date() 函数的格式参数(例如 date("Y", $timestamp) 获取年份,date("W", $timestamp) 获取周数)或在循环中添加额外的逻辑判断即可实现。

通过本教程的学习,您应该已经掌握了使用 PHP 解析 JSON 数据,并根据日期字段进行高效筛选和统计的核心技术。这些技能在处理 API 数据、生成报告和进行数据分析等场景中非常实用。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

457

2023.08.07

json是什么
json是什么

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

549

2023.08.23

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

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

337

2023.10.13

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

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

82

2025.09.10

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

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

338

2023.10.31

php数据类型
php数据类型

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

225

2025.10.31

c语言 数据类型
c语言 数据类型

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

138

2026.02.12

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

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

精品课程

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

共137课时 | 13.6万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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