
本文旨在解决PHP中如何将时间戳转换为易读的时间格式,并将其合并到从数据库获取的JSON数组中的问题。通过使用foreach循环和引用传递,我们将详细介绍如何计算时间差,生成易读的时间字符串,并将其作为新的键值对添加到原始JSON数组中,最终生成包含易读时间信息的JSON数组。
在PHP开发中,经常需要处理从数据库中获取的JSON数据,并对其进行加工处理。一个常见的需求是将时间戳转换为易读的时间格式,例如“几分钟前”、“几小时前”等,并将这些信息添加到原始JSON数组中。本文将详细介绍如何实现这一功能。
使用引用传递修改数组元素
PHP中,可以使用foreach循环遍历数组,并使用引用传递(&)来直接修改数组元素。这允许我们在循环内部修改原始数组,而无需创建新的数组。
以下是基本示例:
立即学习“PHP免费学习笔记(深入)”;
$CommentTime= $this->M_main->GetFeedsCommentTime($FeedId); //假设从数据库获取JSON数据
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; // 添加新的键值对
}
echo json_encode($CommentTime); // 输出修改后的JSON数组代码解释:
- foreach($CommentTime as &$cmt): 使用foreach循环遍历$CommentTime数组。&符号表示引用传递,这意味着$cmt变量是对数组元素的引用,而不是数组元素的副本。任何对$cmt的修改都会直接反映到原始数组中。
- 时间计算部分: 这部分代码计算当前时间与CreatedAt时间戳之间的时间差,并根据时间差生成易读的时间字符串,存储在$PostedTime变量中。
- $cmt['Time'] = $PostedTime;: 将计算得到的易读时间字符串赋值给$cmt数组的Time键。由于$cmt是对原始数组元素的引用,所以这一操作会直接修改原始数组。
- echo json_encode($CommentTime);: 将修改后的$CommentTime数组编码为JSON字符串并输出。
注意事项
- 引用传递: 务必使用引用传递(&),否则无法直接修改原始数组。
- 时间戳准确性: 确保从数据库获取的时间戳是准确的,否则计算出的时间差可能会不正确。
- 时区问题: 如果服务器和数据库的时区不同,可能会导致时间计算错误。需要根据实际情况进行时区转换。
总结
通过使用foreach循环和引用传递,我们可以方便地将时间戳转换为易读的时间格式,并将其合并到从数据库获取的JSON数组中。这种方法简单有效,可以提高用户体验。在实际应用中,可以根据具体需求调整时间计算的逻辑,以满足不同的场景。











