使用php处理来自mysql的许多成员数据

时间:2013-07-12 17:54:40

标签: php mysql

我有一个数组,创建时间已经按AES排序。

$list = array(0 => array('createtime' => 90,'message'=>'ad','user'=>'a'),
        1 => array('createtime' => 91,'message'=>'ae','user'=>'b'),
        2 => array('createtime' => 93,'message'=>'ae','user'=>'b'),
        3 => array('createtime' => 93,'message'=>'ae','user'=>'c'),
        4 => array('createtime' => 94,'message'=>'ah','user'=>'d'),
        5 => array('createtime' => 99,'message'=>'ah','user'=>'a'),
        6 => array('createtime' => 100,'message'=>'ah','user'=>'a'));

As you can see,maybe the array is from a sql table,what I want is to deal with these data,the result of array like this.

$list = array(0 => array('createtime' => 90,'message'=>'ad','user'=>'a'),
        1 => array('createtime' => 91,'message'=>'ae+ae','user'=>'b'),  
        2 => array('createtime' => 93,'message'=>'ae','user'=>'c'),
        3 => array('createtime' => 94,'message'=>'ah','user'=>'d'),
        4 => array('createtime' => 99,'message'=>'ah+ah','user'=>'a'));

是的,您可能会发现5和相同用户数据之间的创建时间组合在一起。我想要的就是这样,将来它可能包含更多用户和更多创建时间。 我编写这样的代码来处理它,但是当我更改我的数据时,例如添加用户或更改用户等等,它的效果不佳。

 $diff = 0;
 $count = 0;
 $d = array();
 $j = array();
 for($i = 1;isset($list[$i]);){
 if ($list[$i]['user'] != $list[$i-1-$count]['user']) {
     if (!in_array($list[$i]['user'], $d)) {
    $d[$diff] = $list[$i]['user'];
    $j[$diff] = $i;
    $count++;
    $diff++;
    $i++;
    continue;
    } else {
    $i++;
    $count++;
    continue;
    }
   }
   if($list[$i]['createtime'] - $list[$i-1-$count]['createtime'] < 5){
  $list[$i-1-$count]['message'] = $list[$i-1-$count]['message'].'<br>'.$list[$i]['message'];
  array_splice($list,$i,1);
   } else if ($count == 0) {
  $i++;
   } else {
 $i = $j[0] + 1;
 $count = 0;
 $diff = 0;
 $d = array();
 $j = array();
   }
 }

似乎有些不对劲。所以我该如何做才能满足我的要求。还应该考虑更短的创建时间之间的用户。谢谢。

1 个答案:

答案 0 :(得分:0)

那么,你是在追求这样的事情吗?

$list = array(0 => array('createtime' => 90,'message'=>'ad','user'=>'a'),
        1 => array('createtime' => 91,'message'=>'ae','user'=>'b'),
        2 => array('createtime' => 93,'message'=>'ae','user'=>'b'),
        3 => array('createtime' => 93,'message'=>'ae','user'=>'c'),
        4 => array('createtime' => 94,'message'=>'ah','user'=>'d'),
        5 => array('createtime' => 99,'message'=>'ah','user'=>'a'),
        6 => array('createtime' => 100,'message'=>'ah','user'=>'a'));

$out = array();

$prevUser = 0;
foreach($list as $key => $value){
    if($value['user'] === $prevUser){
        echo $value['user'], $prevUser, '<br>';
        end($out);
        $k = key($out);
        $out[$k]['message'] .= $value['message'];
        continue;
    }
    $out[] = $value;
    $prevUser = $value['user'];

}
echo '<pre>';
print_r($out);