按列值对二维数组的行进行分组,并在每个组中创建子数组[重复]

问题描述 投票:0回答:3

我有一个数组 $history:

Array (
Array ([id] => 1, [created] => 2012-12-20 22:40, [message] => 'Message1 to display here'),
Array ([id] => 2, [created] => 2012-12-20 22:40, [message] => 'Message2 to display here'),
Array ([id] => 3, [created] => 2012-12-20 22:40, [message] => 'Message3 to display here'),
Array ([id] => 4, [created] => 2012-12-20 21:30, [message] => 'Message4 to display here'),
Array ([id] => 5, [created] => 2012-12-20 21:30, [message] => 'Message5 to display here'),
Array ([id] => 6, [created] => 2012-12-20 20:20, [message] => 'Message6 to display here'),
);

我想显示按日期[创建]字段分组的消息[消息]。

喜欢

2012-12-20 22:40
======================
Message1
Message2
Message3

2012-12-20 21:30
======================
Message4
Message5

我知道有一个函数 array_count_values() 可以提供帮助。

php arrays multidimensional-array grouping
3个回答
2
投票
$arr_by_dates = array();
foreach($arr as $a){
    if (!isset($arr_by_dates[$a['created']])){
        $arr_by_dates[$a['created']] = array();
    }
    $arr_by_dates[$a['created']][] = $a['message'];
}

如果您想在每条记录上保存附加信息,您可以使用数组而不是消息本身:

$arr_by_dates = array();
foreach($arr as $a){
    if (!isset($arr_by_dates[$a['created']])){
        $arr_by_dates[$a['created']] = array();
    }
    $arr_by_dates[$a['created']][] = $a;
    // or  = array('message'=>$a['message'], 'id'=>$a['id']);
}

1
投票

希望这有帮助:

$keys = array();
foreach ($arr as $item) 
{
    $keys[] = strtotime($item['created']);
}
sort($keys);
array_multisort($arr, $keys);

0
投票

您可以转换结构,然后逐步进行打印

$grouped = array();
foreach( $histories as $row ) {
  $date = $row['created'];
  if ( isset($grouped[$date]) ) {
    $grouped[$date][] = $row;
  }
  else {
    $grouped[$date] = array($row);
  }
}

或者您可以随时打印,后者将取决于您按

created
日期订购的结果,但是:

$last = $html = '';
foreach( $histories as $row ) {
  $date = $row['created'];
  if ( $last != $date ) {
    if ( $last ) $html .= '</div>';
    $html .= '<div>';
    $html .= '<h3>'.$date.'</h3>';
    $last = $date;
  }
  $html .= '<p>'.$row['message'].'</p>';
}
$html .= ($html?'</div>':'');
© www.soinside.com 2019 - 2024. All rights reserved.