当前位置:Gxlcms > PHP教程 > 求一利用php快速生成柱状图的函数,现以完成一个简易函数比较慢。该如何解决

求一利用php快速生成柱状图的函数,现以完成一个简易函数比较慢。该如何解决

时间:2021-07-01 10:21:17 帮助过:4人阅读

求一利用php快速生成柱状图的函数,现以完成一个简易函数比较慢。
求一利用php快速生成柱状图的函数,现以完成一个简易函数比较慢。

由于初学,仅会操控CSS生成个简易的柱状图,但我的函数在数据大于25000条的时候超级慢,1万多一点的时候生成图的时间是10多秒。这速度太慢了,求大侠优化。

PHP code


输出图表
       //思路先得到一个一维数组,然后统计值的个数,最后排序
输出 //echo ''; $returnarray2=array(); $db1=new mysqli('localhost','admin','admin','ssq') ; $sql_query='select l1,l2,l3,l4,l5,l6 from hmk_temp_1 as bb limit 0,1000'; $res1=$db1->query($sql_query); while($row1=mysqli_fetch_array($res1,MYSQLI_NUM)) { $returnarray2=array_merge($returnarray2,$row1); } $array_values=array_count_values($returnarray2); ksort($array_values); //print_r($array_values); $rates=round(200/max($array_values),2); echo '$rates='.$rates; echo '

一区

    '; foreach($array_values as $key=>$value){ echo '
  • ' .$value.''.''.$key.'
  • ' ; } echo '

' ; //echo '
'; } $end_time = microtime(true); $end_time *= 1000 * 1000; echo "Total time used : " . ($end_time - $beg_time) . "ms" . PHP_EOL; ?>


------解决方案--------------------
先找出瓶颈是在什么地方

有没考虑过使用 pChart?
------解决方案--------------------
Google有一个库提供。楼主可以查一下。
------解决方案--------------------
输出的 Total time used 看似巨大,但由于计量单位有误,就不足信了
microtime(true) 返回的是秒, * 1000 * 1000 后为微秒,你把它当做毫秒,就放大了 1000 倍

代码简单并不代表运行效率就高,看一下这个测试就知道了
PHP code
$s_time = microtime(true);

$d = range(1, 33);
$r = array();
for($i=0; $i<1000; $i++) {
  shuffle($d);
  $r = array_merge($r, array_slice($d, -6));
}
$r = array_count_values($r);
echo microtime(true) - $s_time, PHP_EOL;

$s_time = microtime(true);
$d = range(1, 33);
$r = array_fill(1, 33, 0);
for($i=0; $i<1000; $i++) {
  shuffle($d);
  foreach(array_slice($d, -6) as $k) $r[$k]++;
}
echo microtime(true) - $s_time, PHP_EOL;

------解决方案--------------------
建议楼主看看:ChartDirector软件,现在有破解的,很好用

人气教程排行