值得一看
广告
彩虹云商城
广告

热门广告位

PHP中合并JSON数组并添加时间信息的实用指南

php中合并json数组并添加时间信息的实用指南

本文旨在帮助开发者掌握如何使用PHP处理从数据库获取的JSON数组数据,并在此基础上,通过计算时间差,将“时间前”的概念整合到原始JSON数组中,最终生成包含id、CreatedAt和Time字段的JSON数据,以便在应用程序中更友好的展示评论时间。

在PHP中,处理JSON数据并对其进行修改是一项常见的任务。以下是如何将时间信息合并到从数据库获取的JSON数组中的详细步骤。

1. 获取JSON数据

首先,从数据库获取数据并将其编码为JSON格式。假设你已经有了一个名为 $CommentTime 的数组,它包含了从数据库中提取的评论数据。

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

$CommentTime= $this->M_main->GetFeedsCommentTime($FeedId);
echo json_encode($CommentTime);

这段代码将 $CommentTime 数组转换为JSON字符串并输出。 $CommentTime 数组的结构如下:

[
{"id":"475","CreatedAt":"1636953999"},
{"id":"474","CreatedAt":"1636953988"},
{"id":"473","CreatedAt":"1636953977"}
]

2. 遍历数组并计算时间差

接下来,使用 foreach 循环遍历数组,并计算每条评论的“时间前”表示。关键在于使用 &$cmt 引用传递,这样可以直接修改原始数组中的元素。

Find JSON Path Online

Find JSON Path Online

Easily find JSON paths within JSON objects using our intuitive Json Path Finder

Find JSON Path Online30

查看详情
Find JSON Path Online

foreach($CommentTime as &$cmt) {
$CreatedAt = $cmt['CreatedAt'];
$PostedAts = $CreatedAt;
$time_ago = $PostedAts;
$cur_time   = time();
$time_elapsed   = $cur_time - $time_ago;
$seconds    = $time_elapsed ;
$minutes    = round($time_elapsed / 60 );
$hours      = round($time_elapsed / 3600);
$days       = round($time_elapsed / 86400 );
$weeks      = round($time_elapsed / 604800);
$months     = round($time_elapsed / 2600640 );
$years      = round($time_elapsed / 31207680 );
// Seconds
if($seconds <= 60){
$PostedTime= "just now";
}
//Minutes
else if($minutes <=60){
if($minutes==1){
$PostedTime= "one minute ago";
} else{
$PostedTime= "$minutes minutes ago";
}
}
//Hours
else if($hours <=24){
if($hours==1){
$PostedTime= "an hour ago";
}else{
$PostedTime= "$hours hrs ago";
}
}
// 将计算出的时间信息添加到数组元素中
$cmt['Time'] = $PostedTime;
}

3. 输出结果

现在,$CommentTime 数组已经包含了 Time 字段,你可以将其编码为JSON并输出。

echo json_encode($CommentTime);

输出结果如下:

[
{"id":"475","CreatedAt":"1636953999","Time":"5 minutes ago"},
{"id":"474","CreatedAt":"1636953988","Time":"10 minutes ago"},
{"id":"473","CreatedAt":"1636953977","Time":"15 minutes ago"}
]

注意事项:

  • 时区问题: time() 函数返回的是服务器的当前时间戳。如果你的数据库中的时间戳存储的是UTC时间,你需要先将其转换为服务器所在的时区,再进行时间差计算,以保证结果的准确性。
  • 数据类型: 确保 $CreatedAt 字段的值是整数类型的时间戳。如果它是字符串类型,你需要使用 intval() 或 (int) 将其转换为整数。
  • 性能优化: 如果你需要处理大量的评论数据,可以考虑使用更高效的时间计算方法,例如使用 DateTime 类。

总结:

通过使用 foreach 循环和引用传递,我们可以方便地修改JSON数组中的元素,并将计算出的时间信息添加到数组中。这种方法简单易懂,适用于大多数情况。 记得在实际应用中处理时区和数据类型,以确保结果的准确性。

相关标签:

php js json go 编码 ai json数组 php json 数据类型 foreach 字符串 int 循环 整数类型 字符串类型 引用传递 数据库 性能优化
温馨提示: 本文最后更新于2025-10-02 22:28:47,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞14赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容