1

我有一组按小时计算的温度数据。有些小时有零数据而不是临时。使用 Google Charts 绘图时,零会导致折线图直线下降。我的临时解决方法是将零值替换为 null,从而导致折线图中断。理想的解决方案是取零两侧的值,并对它们进行平均。该数组按小时排列。帮助?

$array = array(
    "1AM" => "65",
    "2AM" => "66",
    "3AM" => "68",
    "4AM" => "68",
    "5AM" => "68",
    "6AM" => "0",
    "7AM" => "70",
    "8AM" => "71",
    "9AM" => "71",
    "10AM" => "73",
);

这是我用空值替换 0 的脚本:

  $array = array ();
  foreach($parsed_json->history->observations as $key => $value) {
    $temp = (int)$value->tempi;
    if ($temp==0) {
        str_replace(0, null, $temp);
    }
    $hour = $value->date->hour;
    $array[$hour] = $temp;
  };

如果数据是我的,这个示例会很好用,但可惜它来自 JSON 提要。

我会使用 array_walk() 之类的交易吗?我将如何引用数组中的当前位置?任何帮助表示赞赏!

4

3 回答 3

2

我会划掉空部分,然后通过最终数组进行 foreach 循环。

因此,将您当前的代码更改为:

$array = array ();

foreach($parsed_json->history->observations as $key => $value) {
    $temp = (int)$value->tempi;
}

$hour = $value->date->hour;
$array[$hour] = $temp;

并在其下方添加:

foreach($array as $hour => $temp){

  if($temp == "0"){
      $numHour = $hour[0];
      $hourPlus  = ($numHour + 1) . "AM";
      $hourMinus = ($numHour - 1) . "AM";

      $valuePlus  = $array[$hourPlus];
      $valueMinus = $array[$hourMinus];

      $average = ($valuePlus + $valueMinus)/2;

      $array[$hour] = $average;
  }

}
?>

这当然假设零两侧的值也不为零。您可能想在其中某处添加检查。

经过测试和验证的方法。

于 2012-08-02T16:34:34.893 回答
0

你不能按照以下方式做一些事情:

str_replace(0, ((($key-1)+($key+1))/2), $temp);

其中 $key 是数组位置,取 0 之前的值,0 之后的值相加,然后除以 2 得到平均值。

于 2012-08-02T16:19:24.047 回答
0

我会让你理清如果第一个、最后一个或连续的值为 0 会发生什么。

$the_keys=array_keys($array);
foreach($the_key as $index=>$key)
{
    if($array[$key]==0)
    {
        $array[$key]=($array[$the_key[$index-1]]+$array[$the_key[$index+1]]/2);
    }
}
于 2012-08-02T16:31:11.697 回答