首页 > 作文

PHP实现动态柱状图改进版

更新时间:2023-04-06 19:21:34 阅读: 评论:0

本文实例分析了php实现动态柱状图的改进版。分享给大家供大家参考。具体分析如下:

前面已经写过如果只做动态柱状图的情况,其实原理还是很简单的。因为昨天下午有新的需求,今天上午又修改了一番,并将数据根据编号不同分割显示在表中。

下面把代码粘出来,方便以后自己查看,思路只是一时的火花,今天我想出来这么做,不一定下次还能想得到,也不用费劲的去想,所以写成笔记是比较好的形式。

<!doctype html> <?php // 计算上一个月的今天 function last_month_today($time) {   $last_month_time = mktime(date("g", $time), date("i", $time), date("s", $time), date("n", $time), 0, date("y", $time));   $last_month_t = date("t", $last_month_time);   if ($last_month_t < date("j", $time)) {   一亩地是多少return date("y-m-t h:i:s", $last_month_time);   }   return date(date("y-m", $last_month_time) . "-d", $time); } ?> <?php include dirname(dirname(dirname(__file__))) . '/config.php'; $enddate = date('y-m-d'); $date = strtotime($enddate); $begindate = last_month_today($date); $sql = 'lect count(*) from newpro where p_date>\'' . $begindate . '\' and p歌曲心雨_date<\'' . $enddate . '\''; $d = db()->query($sql)->fetch(pdo::fetch_num); $sql2 = $sql . ' and is_pa_check_first=1 and is_pa_check_cond=1 and is_pa_check_third=1'; $d2 = db()->query($sql2)->fetch(pdo::fetch_num); $sql3 = $sql . ' and is_pa_check_first=1'; $d3 = db()->query($sql3)->fetch(pdo::fetch_num); $sql4 = $sql . ' and is_pa_check_first=1 and is_pa_check_cond=1'; $d4 = db()->query($sql4)->fetch(pdo::fetch_num); // 查询每个人通过审核的情况: $sqlab = 'lect d_m,sum(sroce) as total_score,count(d_m) as total_number from newpro   where is_pa_check_first=1   and is_pa_check_cond=1   and is_pa_check_third =1 group by d_m'; $row = db()->query($sqlab)->fetchall(pdo::fetch_assoc); ?> <html> <head> <meta chart="utf-8" /> <style> div {   background-color: #669900;   width: 50px; } #div1 {   height: 200px; } #table td { } </style> <script type="text/javascript" src="../../../js/jquery-1.7.2.min.js"></script> </head> <body>   <h3 align="center">近一个月总的情况&are的音标lt;/h3>   <table border="0" align="center" id="table1">   <caption>      <?php echo "时间:".$begindate."至".$enddate?>      </caption>   <tr align="center" valign="bottom">     <td>     <p><?php echo $d[0]?></p>     <div id="div1"></div>     </td>     <td>     <p><?php echo $d3[0]?></p>     <div style="height:<?php $str=floor(($d3[0]/$d[0])*200); echo $str.'px'?>"></div>     </td>     <td>     <p><?php echo $d4[0]?></p>     <div style="height:<?php $str=floor(($d4[0]/$d[0])*200); echo $str.'px'?>"></div>     </td>     <td>     <p><?php echo $d2[0]?></p>     <div style="height:<?php $str=floor(($d2[0]/$d[0])*200); echo $str.'px'?>"></div>     </td>   </tr>  <tr align="center" valign="top">     <td><p>总计</p></td>     <td><p>一审通过</p></td>     <td><p>二审通过</p></td>     <td><p>审核通过</p></td>   </tr>   </table>   <h3 align="center">近一个月每个人的情况</h3>   <table border="0" width="100%">   <caption>每个人的完成情况如下表:</caption>  <!-- 因为总的列数比较长,如果显示在一个表格中,数据会很拥挤,多的话根本就看不清楚。      所以需要将数据进行分割,根据长度进行动态的分割,显示在多张表中。    -->     <?php     $arr = array_chunk($row,2,fal);//2表示分割的单位长度,fal表示索引从0开始     foreach($arr as $newrow){       $thstr = "<th style='background-color:#669900' width='110px' height='30px'>产品开发编号</th>";       $trstr_total_score = "<tr align='center' style='background-color:silver' height='25px'><td>总分</td>";       $trstr_total_number = "<tr align='center' style='background-color:silver' height='25px'><td>总数量</td>";       $trstr_average_score = "<tr align='center' style='background-color:silve星月的来由r' height='25px'><td>平均分</td>";       $resultstr = "";       foreach ($newrow as $key => $value) {       // echo $key."=>".$value."<br/>";       $x = 0;       foreach ($value as $key2 => $value2) {         // echo $key2 . "=>" . $value2 . "<br/>";         if ($key2 == 'd_m') {         $thstr .= "<th style='background-color:#669900'>" . $value2 . "</th>"; // 表头         } elif ($key2 == 'total_score') {         $value2 = sprintf("%.2f", $value2); //保留2位小数         $trstr_total_score .= "<td>" . $value2 . "</td>";         $x += $value2;         } elif ($key2 == 'total_number') {          $trstr_total_number .= "<td>" . $value2 . "</td>";         $x /= $value2;         }       }       $x = sprintf("%.2f",$x);       $trstr_average_score .= "<td>" . $x . "</td>";       }       echo "<table border='0' width='100%'>";       echo $thstr;       echo $trstr_total_number . "</tr>";       echo $trstr_total_score . "</tr>";       echo $trstr_average_score . 口臭怎么去除"</tr>";       echo "</table>";       echo "<p height='150px'></p>";     }     ?>   </table> </body> </html>

数据库方便就不弄了,其实,根据查询的表名和字段名,是很容易建一个测试的数据表的。关键是思路,无论怎么变,思路是关键。

为了更加方便的了解代码的效果,截个图吧

希望本文所述对大家的php程序设计有所帮助。

本文发布于:2023-04-06 19:21:33,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/51c5402b0334dd72c213e99d713425a3.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP实现动态柱状图改进版.doc

本文 PDF 下载地址:PHP实现动态柱状图改进版.pdf

标签:每个人   情况   思路   动态
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图