<?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
$arr[$key][] = array("value"=>$value); if($somecondition){
foreach($arr as $k => $v){
$arr[$k][] = array("value"=>"");
}
}
}?>有这么一种情况, 循环创建一个二维数组并添加元素, 但是出现某个条件$somecondition的时候,就往数组中每个$key中添加一个value为空的元素。添加完以后用看,发现增加的为空的元素都跑到了数组的最前面,这是为何? 怎么才能正确添加啊。二维数组PHP
所以
$arr[$key][] = array("value"=>$value);
和
$arr[$k][] = array("value"=>"");
赋值的位置是不一样的你最好贴出你需要的格式示例
<?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}
}数组前面多出的[],目前看不影响画图,但终归不和标准格式相匹配。
while(mysql_fetch_array){
$arr[$key][] = array("value"=>$value);
if($somecondition){
$arr[$key][] = array("value"=>"");
}
}
.
$somecondition就是判断mysql_fetch_array中的到的时间点比上一个时间点差距太大,那么我就按照间隔补上时间点,这个时候这个时间点我应该是给所有的key补个空值,所以我就用了foreach遍历一遍,补充的结果就是补的空值跑到了数组的最前面。应该还是要foreach吧。。
while(mysql_fetch_array){
if($somecondition){ //如果差距太大
$arr[$key][] = array("value"=>""); //则插入空值,多于一个时用 for 循环
}
$arr[$key][] = array("value"=>$value); //加入数据
}
我知道哪里错了。。我mysql查询出来的语句,不是按照时间点的顺序的,是按照key的顺序排的坑爹了。。
第一次按照key的顺序排
第二次按照时间点的顺序排
谢谢了。。其实逻辑和实现都没错,是我mysql不精,group by后面两个条件顺序写反了。