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

WBOY
Freigeben: 2016-06-13 13:27:58
Original
983 Leute haben es durchsucht

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

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

PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
<style type="text/css">
.chart {
    font-family: Tahoma;
    font-size: 12px;
    border: 1px solid #ccc;
    width:auto;
    float: left;
    margin: 0;
    padding: .4em .1em;
    height:auto;
}
.chart ul {
    
    
    margin:0px;
    height:auto;
    text-align: center;
    display:block;
    background-repeat: no-repeat;
    background-position: center bottom;
    background-attachment: fixed;
}
.chart li {
    list-style: none;
    float: left;
    width: 35px;
    height:200px;
    text-align: center;
    display:block;
    background-repeat: no-repeat;
    background-position: center bottom;
    background-attachment: fixed;
}

.b {
    display: block;
    width:15px;
    background-color:#000;
    margin-right: auto;
    margin-left: auto;    
}

.a {
    
    height:12px;
    width:35px;
    background-color:#fff;
        
    
    padding: 0px;
}
</style>
<?php $beg_time = microtime(true);
$beg_time *= 1000 * 1000;

create_chart2();
function create_chart2() {//x一维数组直接输出图表
       //思路先得到一个一维数组,然后统计值的个数,最后排序输出
       
       //echo '<table>';
       $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 '<div class="chart"> <p>一区</p>  <ul>';
       foreach($array_values as $key=>$value){
          echo '<li>
<span class="a" style="margin-top:'.(210-$value*$rates).'px;">' .$value.'</span><span class="b" style="height:'.($value*$rates).'px;">'.'</span><span class="a">'.$key.'</span>
</li>' ;
       }
  
  echo '</ul>
</div>
<p style="clear: both"></p>' ;
 //echo ''; 
}

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

Nach dem Login kopieren


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

有没考虑过使用 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<font color="#e78608">------解决方案--------------------</font><br>建议楼主看看:ChartDirector软件,现在有破解的,很好用 <div class="clear">
                 
              
              
        
            </div>
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage