ECharts绘制数据图表

使用ECharts绘制数据图表,使用php自带的函数将数组转换成json格式(ECharts要求的格式)。ECharts可自己定制需要的图表,并导出为js文件。

<?php
include("conn.php");
session_start();
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT); # 数据库语言出错时可报错
?>

<?php
    if (isset($_SESSION['name'])) {
        # 如果名字存在会话里
        $name = $_SESSION['name'];
    }
    else $name = '002';  # 002是用于调试的用户名

    # 在实验数据库中,找到002并调取他实验一的成绩数据,分数以及测试顺序。升序排列
    $sql_user = "SELECT score,insert_id from experiment_no_1 where name='$name' order by insert_id asc";  

    # 执行数据库查找操作,将结果赋予$query_user
    $query_user = mysqli_query($conn,$sql_user);
    
    # 把所有数据组成的数组结果存入$result_total
    $result_total = mysqli_fetch_all($query_user);

    # 查看该数组数据
    print_r($result_total); echo "<br>"; 

    # 定义一个成绩变量,将数组$result_total的第一列取出
    $score = array_column($result_total, '0');
    
    # 计算$score的数量,调试用
    $c = count($score); echo $c.'<br>';

    # 打印成绩,调试用
    print_r($score); echo "<br>"; 

    # 定义一个实验顺序变量,将数组$result_total的第二列取出
    $id = array_column($result_total, '1');

    # 将成绩变量由数组形式转换成json格式,并将字符串中的数字转换成数字类型
    $score1 = json_encode($score, JSON_NUMERIC_CHECK);
    
    # 打印转码后的成绩,调试用
    echo "$score1".'<br>';

    # 将实验顺序变量由数组形式转换成json格式
    $id1 = json_encode($id, JSON_NUMERIC_CHECK);
?>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>ECharts绘制用户同一实验不同成绩</title>
    <!-- 引入 echarts.js -->
    <script src="echarts.js"></script>
</head>
<body>
    <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
    <div id="main" style="width: 400px;height:400px;left:50%;top:50%;
    transform: translate(-50%,-0%);"></div>
    <script type="text/javascript">
        // 基于准备好的dom,初始化echarts实例,具体接口参考官方文档
        var myChart = echarts.init(document.getElementById('main'));

        // 指定图表的配置项和数据
        var option = {
            title: {
                text: '实验一成绩统计'
            },
            tooltip: {},
            legend: {
                data:['score']
            },
            xAxis: {
                data: <?php echo "$id1"; ?>
            },
            yAxis: {},
            series: [{
                name: 'score',
                type: 'line',
                smooth: 0.5,
                data: <?php echo "$score1"; ?>
            }]
        };

        // 使用刚指定的配置项和数据显示图表
        myChart.setOption(option);
    </script>
</body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值