第一步:准备数据库

这部分内容查看我的上一篇内容:
python flask p5.js mysql 实现数据库查询并网页显示数据
通过前端输入相关测试数据:
请添加图片描述

请添加图片描述
数据库中查看信息:
请添加图片描述

第二步:准备Echart

下载链接:(需下载一个js文件)
https://github.com/apache/echarts/blob/5.4.2/dist/echarts.min.js
点进去之后右击Raw,选择链接另存为请添加图片描述
请添加图片描述
放在自己项目的js文件夹下面
然后去官网找到你想要下载的示例
https://echarts.apache.org/examples/zh/index.html#chart-type-line

请添加图片描述
我们这边以基础平滑折线图为例子点进去然后再点下载示例
请添加图片描述
请添加图片描述
下载好是一个html文件
你可以直接用这个文件拖进去自己的文件夹或者新建一个复制进去也是可以的
请添加图片描述
示例是用下面这种方式引入echarts.min.js的

 <script type="text/javascript" src="https://fastly.jsdelivr.net/npm/echarts@5.4.2/dist/echarts.min.js"></script>

如果想用我们刚刚放在本地的就用下面这条语句

<script  src="{{ url_for('static',filename = 'js/echarts.min.js') }}"></script>

请添加图片描述
我们看我们复制过来的代码
请添加图片描述

xAxis 里面的data表示x轴的数据是什么
series 里面的data是你变化的数据
y轴的数据范围会根据你变化的数据自己定好上下界的

我们将来展示修改的就是 这两个部分
运行一下先看看报不报错再进行下一步哦
请添加图片描述

第三步:绑定数据库信息和图表

后端方面:
在蓝图下面新建一个py文件,蓝图的新建方法就是右击项目新建python Package,命名就是 blueprint
(ps:如果项目不大写在app.py中也可)
代码就是:

from flask import render_template
from models import User


@app.route('/chart')
def chart():
    items = User.query.all()
    print(items)
    return render_template('chart.html', items=items)

请添加图片描述
蓝图下新建chart.py

from flask import Blueprint, render_template
from models import User

bp = Blueprint("chart", __name__, url_prefix="/")

@bp.route('/chart')
def chart():
    items = User.query.all()
    print(items)
    return render_template('chart.html', items=items)

代码的目的就是查到数据库所有的数据然后转发给chart.html,这个chart.html就是咋们刚刚复制进来的那个html文件

我们现在数据库中的信息是:
请添加图片描述
然后我们想让变化的数据是age,横坐标展示我们的姓名
这个时候我们去改html文件
请添加图片描述
只需要改这两个data,其他都不需要动
我们那会不是将items数据库的记录传到了这个html文件,我们现在就要用这个items
请添加图片描述
改动就是以循环的方式将记录的一个对象输出
最后我们访问一下http://127.0.0.1:5000/chart
请添加图片描述
然后就得到了我们想要的效果
附上chart .html文件代码:

<!--
	此示例下载自 https://echarts.apache.org/examples/zh/editor.html?c=line-smooth
-->
<!DOCTYPE html>
<html lang="zh-CN" style="height: 100%">
<head>
  <meta charset="utf-8">
</head>
<body style="height: 100%; margin: 0">
  <div id="container" style="height: 100%"></div>


  <script  src="{{ url_for('static',filename = 'js/echarts.min.js') }}"></script>
  <script type="text/javascript">
    var dom = document.getElementById('container');
    var myChart = echarts.init(dom, null, {
      renderer: 'canvas',
      useDirtyRect: false
    });
    var app = {};
    var option;

    option = {
        xAxis: {
            type: 'category',
            data:[
                {% for item in items %}
                    "{{ item.username}}",
                {% endfor %}
                ]},

        yAxis: {
            type: 'value'
            },
        series: [
            {
            data: [

                {% for item in items %}
                    "{{ item.age}}",
                {% endfor %}

            ],
            type: 'line',
            smooth: true
            }
        ]
    };
    if (option && typeof option === 'object') {
        myChart.setOption(option);
    }
    window.addEventListener('resize', myChart.resize);

  </script>

</body>
</html>

⚠️需要注意的几个地方

1、注意自己在@bp.route('/chart')配置的路径是否正确
2、注意自己循环里面item.age数据库字段是否一样
请添加图片描述
3、检查自己后端是否返回数据库的所有数据
请添加图片描述

请添加图片描述
提示框有数据才可以,如果数据库有东西但打印出来[ ] 再回去检查你的数据库连接和后端是否有拼写错误

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐