<?php        while(mysql_fetch_array){
                $arr[$key][] = array("value"=>$value);                if($somecondition){
                        foreach($arr as $k => $v){
                                $arr[$k][] = array("value"=>"");
                        }
                }
        }?>有这么一种情况, 循环创建一个二维数组并添加元素, 但是出现某个条件$somecondition的时候,就往数组中每个$key中添加一个value为空的元素。添加完以后用看,发现增加的为空的元素都跑到了数组的最前面,这是为何? 怎么才能正确添加啊。二维数组PHP

解决方案 »

  1.   

    至少你的描述是有问题 $key 和 $k 并不是一回事
    所以
    $arr[$key][] = array("value"=>$value);
    和 
    $arr[$k][] = array("value"=>"");
    赋值的位置是不一样的你最好贴出你需要的格式示例
      

  2.   


    <?php           
            while(mysql_fetch_array($res1)){
                    $arr[$key][] = array(); //为了确定每个key在数组的前后顺序
            }
             while(mysql_fetch_array($res1)){                          $arr[$key][] = array("value"=>$value);                                   if($somecondition){                                                 foreach($arr as $k => $v){                                 
                                    $arr[$k][] = array("value"=>"");                         
                            }                 
                    }         
            }   
    ?>我整个的过程是这样的。
    先在while(mysql_fetch_array($res1))中确定每个key的先后顺序。
    然后在while(mysql_fetch_array($res2))中在每个key增加元素,遇到某个条件的时候,就补个空元素。我得出数组的是:
    {
    key1:[[],{"value":""},{"value":""},{"value":""},{"value":36.63},{"value":35.97},{"value":32.8},{"value":32.65}
    key2:[[],{"value":""},{"value":""},{"value":""},{"value":36.63},{"value":35.97},{"value":32.8},{"value":32.65}
    }
    而我原计划得到的数组是:
    {
    key1:[{"value":36.63},{"value":35.97},{"value":""},{"value":""},{"value":""},{"value":32.8},{"value":32.65}
    key2:[{"value":36.63},{"value":35.97},{"value":""},{"value":""},{"value":""},{"value":32.8},{"value":32.65}
    }数组前面多出的[],目前看不影响画图,但终归不和标准格式相匹配。
      

  3.   

    回2L,我在foreach中打印了$k的名字, 确实是和外层的while中的$key是一样的啊。回5L,数据库存的是一些个时间点,每个时间点有几十种$key对应的值,我现在的做法,是先查询一遍,例如是全天的,算个总排名top10确定$key的先后顺序,然后再查一遍赋值。要是直接在数据库中关联查询,我目前mysql的select命令很不熟悉,又担心某个key前个时间点在第10位,下个时间点在第11位,到时候又统计不到了,
      

  4.   

    查第一次选个较大的范围算总排名top10, 能够一定程度反映总体的一个趋势, 中间那些时间点排名并不是和总排名一样,但大体趋势是一致,而且我查的还是历史记录。然后由于某些原因,某些时间点没有记录,我就想在这个时间点给每个key插个空值进去,就是不知道为啥插进去的空值跑到了数组的最前面。
      

  5.   

    对了,假如是一个一维数组的话,我直接可以用arsort函数进行排名,但是由于json格式固定了,所以只能弄格式规定的那种二维的。
      

  6.   

    有点明白你的意思了
    while(mysql_fetch_array){
      $arr[$key][] = array("value"=>$value);
      if($somecondition){
        $arr[$key][] = array("value"=>"");
      }
    }
      

  7.   


    .
    $somecondition就是判断mysql_fetch_array中的到的时间点比上一个时间点差距太大,那么我就按照间隔补上时间点,这个时候这个时间点我应该是给所有的key补个空值,所以我就用了foreach遍历一遍,补充的结果就是补的空值跑到了数组的最前面。应该还是要foreach吧。。
      

  8.   

    思路应该是这样的
    while(mysql_fetch_array){
      if($somecondition){ //如果差距太大
        $arr[$key][] = array("value"=>""); //则插入空值,多于一个时用 for 循环
      }
      $arr[$key][] = array("value"=>$value); //加入数据
    }
      

  9.   


    我知道哪里错了。。我mysql查询出来的语句,不是按照时间点的顺序的,是按照key的顺序排的坑爹了。。
      

  10.   

    你不是两次查询的吗?
    第一次按照key的顺序排
    第二次按照时间点的顺序排
      

  11.   


    谢谢了。。其实逻辑和实现都没错,是我mysql不精,group by后面两个条件顺序写反了。