利用FLASK+ECharts构建网站

FLASK简介

Flask是Armin ronacher用 Python 语言基于 Werkzeug 工具箱编写的轻量级Web开发框架。其 WSGI 工具箱采用 Werkzeug(路由模块),模板引擎则使用 Jinja2。这两个也是 Flask 框架的核心。网上对此介绍较多,具体可以参见:http://flask.pocoo.org/

Echarts简介

ECharts,是一个纯 Javascript 的图表库,可在 PC 和移动设备上运行,兼容当前大部分浏览器,底层依赖Canvas 类库 ZRender,提供可个性化定制的数据可视化图表。

ECharts是由数据驱动,通过数据的变化驱动图表展现的改变。编程过程就是获取数据,填入数据,系统自动过度表现数据的变化。Echarts提供了折线图、柱状图、散点图、饼图、K线图等组件,以及用于统计的盒形图,用于地理数据可视化的地图,热力图,线图,用于关系数据可视化的关系图,treemap,多维数据可视化的平行坐标,还有用于 BI 的漏斗图,仪表盘,并且支持图与图之间的组合。具体可以参见:http://echarts.baidu.com/index.html

FLASK+Echarts构建数据绘图网站

STEP1

参考如下代码,构建FLASK实例

from flask import Flask # 导入flask类 
#flask 类的实例化 
app = Flask(__name__)
 # flask 路由地址 / 
@app.route('/admin',methods=['GET','POST']) 
def admin(): 
    return 'Hello Flask' 

if __name__ == '__main__': 
    app.run() # 运行flask
STEP2

在服务器端,获取和处理外部数据。以下仅为示例,具体应用需要进一步优化处理。

import csv
import pandas as pd
from io import BytesIO
from urllib import request as url_req


@main.route('/admin',methods=['GET','POST'])
def admin():
    # 仅做示例。从chinamoney网站获取FR007、DR007数据,跨度1年。
    url='http://www.chinamoney.com.cn/dqs/rest/cm-u-bk-currency/FrrHisExcel?lang=CN&startDate=2017-10-10&endDate=2018-10-09'
    s = url_req.urlopen(url).read()#.decode()  # 1 读取数据串

    dfile=BytesIO(s)

    creader = pd.read_excel(dfile) # dfile
    tmp_creader = creader[:-2]
    tmp_creader = tmp_creader.sort_values('交易日期')

    date_list = tmp_creader['交易日期'].tolist()
    FR007_list = tmp_creader['FR007(%)'].tolist()
    DR007_list = tmp_creader['FDR007(%)'].tolist()
    SPREAD_list = (tmp_creader['FR007(%)'] - tmp_creader['FDR007(%)']) *100.0
    SPREAD_list = np.around(SPREAD_list,0).tolist()

    return render_template('index1.html',date_list=date_list, \
                                        FR007_list = FR007_list, \
                                        DR007_list = DR007_list, \
                                        SPREAD_list = SPREAD_list)

STEP3

在“templates”文件下的index1.html中,使用javascript制作Echarts图例。实现两图并列。

<div id="main2" style="width: 800px;height:600px;margin: 0 auto;"></div>

<script  type="text/javascript">
      
    // 基于准备好的dom,初始化echarts实例
    var myChart2 = echarts.init(document.getElementById('main2'));
    
    // 指定图表的配置项和数据
    var option2 = {
        title: {
            text: '货币市场利率'
        },
        tooltip: {
            trigger:'axis'
        },
        legend: {
            data:['FR007','DR007','SPREAD']
        },
        xAxis: [{
                    type: 'category',
                    boundaryGap:false,
                    //nameRotate:30,
                    data: {{date_list|safe}} ,
                    gridIndex: 0
                },
                {
                    type: 'category',
                    boundaryGap:false,
                    //nameRotate:30,
                    data: {{date_list|safe}} ,
                    gridIndex:1
                }],
        // 定义双Y轴
        yAxis: [{
                    type: 'value',
                    name: 'RATE(%)',
                    gridIndex: 0
                },
                {   
                    type: 'value',
                    name: 'FR-DR(bp)',
                    gridIndex: 1
                }],
        grid: [{
                    bottom: '50%'
                }, {
                    top: '60%'
                }],  

        series: [{
            name: 'FR007',
            type: 'line',
            data: {{FR007_list}},
         
        },
        {
            name: 'DR007',
            type: 'line',
            xAxisIndex: 0,
            yAxisIndex: 0,
            data: {{DR007_list}}
        } ,
        {
            name: 'SPREAD',
            type: 'bar',
            xAxisIndex: 1,
            yAxisIndex: 1,
            data: {{SPREAD_list }} 
        } ]
    };
    // 使用刚指定的配置项和数据显示图表。
    myChart2.setOption(option2);
         
</script>
STEP4

展示效果


货币市场利率.JPG

本人购买了云服务器,并在上面部署了FLASK+Echarts构建的网站,供学习交流。

http://111.231.194.77:8080/main/admin

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354