2013-05-18 27 views
0

我有其中每列是一个国家数据的行的数据库中阵列结构和键。在这个例子中,有4个国家(列)和3个行,尽管每个国家的数量都会发生变化,所以需要动态的输入。我想标准化每一行,因此最小值为0,最大值为100,同时保留原始数据库的4 x 3数组结构,以便根据请求提取行或列。如何保持calcultations

最终输出将被传递到Javascript来以图形的形式来呈现。 我已经想出了正确的数据正常化的代码,但输出是一个长阵列12 x 1和列名已被删除。

我想知道是否有人知道我如何保持$ScoreNorm的结构与$dataA的输出相同?

<?php 
$conn=mysql_connect("relevant inputs"); 

if(! $conn) 
{ 
    die('Could not connect: ' . mysql_error()); 
} 
    mysql_select_db("db-name"); 

    $dataArray = "SELECT * FROM data2012" 
     or die(mysql_error()); 

$data2012=mysql_query($dataArray, $conn); 
if(! $data2012) 
{ 
die('Could not get data: ' . mysql_error()); 
} 

$ScoreNorm = array(); 
$dataA = array(); 

while($row = mysql_fetch_assoc($data2012)) 
{ 
$dataA[] = $row; 
$max_val = max($row); 
$min_val = min($row); 

    foreach($row as $key => &$dataAitem) 
     { 
    $ScoreNorm[] = array((($dataAitem - $min_val)/($max_val - $min_val))*100); 
     } 
} 
echo json_encode($dataA) . "<br />"; 
echo json_encode($ScoreNorm) . "<br />"; 

echo $dataA[1]['France']; 
mysql_close($conn); 
?> 

的输出回波json_encode($数据A)是

[{"China":"11.000","Australia":"8.300","France":"12.600","UK":"6.220"},{"China":"2.000","Australia":"1.000","France":"4.000","UK":"5.000"},{"China":"39548.000","Australia":"25487.000","France":"245.000","UK":"2547852.000"}] 

凡作为输出回波json_encode($ ScoreNorm)是

[[74.921630094],[32.6018808777],[100],[0],[25],[0],[75],[100],[1.54274187502],[0.990812162158],[0],[100]] 

要重申,我想$ScoreNorm保持$dataA format。任何想法不胜感激。

+0

[**在新的代码,请不要使用'mysql_ *'功能**](http://bit.ly/phpmsql )。他们不再被维护[并且被正式弃用](http://j.mp/XqV7Lp)。看到[**红框**](http://j.mp/Te9zIL)?学习[*准备的语句*](http://j.mp/T9hLWi),并使用[PDO](http://php.net/pdo)或[MySQLi](http://php.net/ mysqli) - [这篇文章](http://j.mp/QEx8IB)将帮助你决定哪个。如果你选择PDO,[这里是一个很好的教程](http://j.mp/PoWehJ)。 –

回答

0

我已经破解了第二的foreach伸到自己的循环,因为我不知道你使用的列名,这和我平时也都取了这一点。我也在假设国名是关键,而数字是价值。如果你需要的是帮助,只是让我知道什么是列名在你的结构,否则检查了这一点:

$dataA = array(); 
$ScoreNorm = array(); 
while($row = mysql_fetch_assoc($data2012)) 
{ 

    $dataA[] = $row; 

} 


foreach($dataA as $dataAkey => $dataAvar){ 

$max_val = max($dataAvar); 
$min_val = min($dataAvar); 

$ScoreNormTemp=array(); 

    foreach($row as $country => $value) 
    { 

     $ScoreNormTemp[$country] = 
      array((($value - $min_val)/($max_val - $min_val))*100); 

    } 

$ScoreNorm[] = $ScoreNormTemp; 

} 

您当前填充数组中的一个尺寸,当你需要一个新的阵列然后在最后添加到数组数组中。

0

而不是创建$ ScoreNorm,该行添加到$数据A为正常,然后修改它,并把它添加到$ ScoreNorm的:

while($row = mysql_fetch_assoc($data2012)) 
{ 
    $dataA[] = $row; 
    $max_val = max($row); 
    $min_val = min($row); 

    foreach($row as &$dataAitem) { 
     $dataAitem = (($dataAitem - $min_val)/($max_val - $min_val))*100; 
    } 
    $ScoreNorm[] = $row; 
} 
0

林不知道我理解正确,什么妳后,但我会尝试没有少

$output_arr = new array(); //final output 
while($row = mysql_fetch_assoc($data2012)) 
{ 
$dataA[] = $row; 
$max_val = max($row); 
$min_val = min($row); 

$row_arr = new array(); 
    foreach($row as $key => &$dataAitem) // this create temp array keeping the property name 
     { 
      $row_arr[$key] = normalized_value ($dataitem); //put your func here.. to get this value for this country 
     } 

array_push ($output_arr,$row_arr); //now add this to final output array.. 
} 

echo json_encode ($output_arr); //should have what u seek, i hope 
0

我想知道是否有人知道我怎么能保持相同的结构$ ScoreNorm作为为$数据A

输出

你只需要维护标准化数组中的键来实现这一点。

$ScoreNorm = array(); 
$dataA  = array(); 

while ($row = mysql_fetch_assoc($data2012)) { 
    $dataA[] = $row; 
    $max_val = max($row); 
    $min_val = min($row); 

    $rowNorm = array();  
    foreach ($row as $key => $dataAitem) { 
     $rowNorm[$key] = ($dataAitem - $min_val)/($max_val - $min_val)*100; 
    } 
    $ScoreNorm[] = $rowNorm; 
} 

我建议你圆的标准值,因为它redices JSON响应的长度和比例不确实包含相关信息。所以,我线

 $rowNorm[$key] = ($dataAitem - $min_val)/($max_val - $min_val)*100; 

改变

 $rowNorm[$key] = (int)round(($dataAitem - $min_val)/($max_val - $min_val)*100);