我有其中每列是一个国家数据的行的数据库中阵列结构和键。在这个例子中,有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
。任何想法不胜感激。
[**在新的代码,请不要使用'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)。 –