pyecharts結合flask框架的使用
介紹
本文主要介紹如何在Flask框架中使用pyecharts
,關于Flask框架使用這里不做具體說明~
Flask模板渲染
首先需要創(chuàng)建一個flask項目,flask項目對目錄結構要求不高,但是如果是前后端混合項目的話,模板文件必須存放在templates
文件夾下,否則視圖函數(shù)返回模板文件時會提示找不到對應的文件。下面是flask項目的簡單目錄結構:
. ├── server.py └── templates
下述代碼是server.py
中的示例的代碼:
from flask import Flask from jinja2 import Markup, Environment, FileSystemLoader? from pyecharts import options as opts from pyecharts.charts import Bar? app = Flask(__name__, static_folder="templates")? def bar_base() -> Bar: c = ( Bar() .add_xaxis(["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"]) .add_yaxis("商家A", [5, 20, 36, 10, 75, 90]) .add_yaxis("商家B", [15, 25, 16, 55, 48, 8]) .set_global_opts(title_opts=opts.TitleOpts(title="Bar-基本示例", subtitle="我是副標題")) ) return c? @app.route("/") def index(): c = bar_base() return Markup(c.render_embed())? if __name__ == "__main__": app.run()
運行上述代碼,使用瀏覽器打開http://127.0.0.1:5000 即可訪問服務,具體效果如下圖所示:
Flask前后端分離
創(chuàng)建flask項目和上述文件目錄保持一致,前后端分離的情況下,就需要后端將pyecharts生成的圖表返回給前端,方法就是可以將圖表生成到一個html文件中,然后返回給前端即可。
需要新建 HTML 文件保存位于項目根目錄的 templates 文件夾,這里以如下 index.html 為例. 主要用到了 jquery
和 pyecharts
管理的 echarts.min.js
依賴。
下述是index.html
中的代碼:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Awesome-pyecharts</title> <script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.min.js"></script> <script type="text/javascript" src="https://assets.pyecharts.org/assets/echarts.min.js"></script> </head> <body> <div id="bar" style="width:1000px; height:600px;"></div> <script> $( function () { var chart = echarts.init(document.getElementById('bar'), 'white', {renderer: 'canvas'}); $.ajax({ type: "GET", url: "http://127.0.0.1:5000/barChart", dataType: 'json', success: function (result) { chart.setOption(result); } }); } ) </script> </body> </html>
然后就需要編寫后端的代碼了,包括flask服務以及pyecharts
生成圖表,目錄結構和模板渲染一致,這里需要注意一個問題,目前由于 json 數(shù)據(jù)類型的問題,無法將 pyecharts 中的 JSCode 類型的數(shù)據(jù)轉換成 json 數(shù)據(jù)格式返回到前端頁面中使用。因此在使用前后端分離的情況下盡量避免使用 JSCode 進行畫圖。
下面是server.py
中的后端代碼:
from random import randrange? from flask import Flask, render_template? from pyecharts import options as opts from pyecharts.charts import Bar?? app = Flask(__name__, static_folder="templates")? def bar_base() -> Bar: c = ( Bar() .add_xaxis(["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"]) .add_yaxis("商家A", [randrange(0, 100) for _ in range(6)]) .add_yaxis("商家B", [randrange(0, 100) for _ in range(6)]) .set_global_opts(title_opts=opts.TitleOpts(title="Bar-基本示例", subtitle="我是副標題")) ) return c? @app.route("/") def index(): return render_template("index.html")? @app.route("/barChart") def get_bar_chart(): c = bar_base() return c.dump_options_with_quotes()? if __name__ == "__main__": app.run()
同樣運行該項目,使用瀏覽器打開 http://127.0.0.1:5000 即可訪問服務。
總結
兩篇文章只是介紹了pyecharts
模塊的一些簡單使用,在官方文檔中還有很多進階使用,經(jīng)常進行圖表分析的開發(fā)人員們可以參考官方文檔進行學習。
到此這篇關于pyecharts結合flask框架的使用的文章就介紹到這了,更多相關pyecharts flask框架內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python爬蟲實現(xiàn)全國失信被執(zhí)行人名單查詢功能示例
這篇文章主要介紹了Python爬蟲實現(xiàn)全國失信被執(zhí)行人名單查詢功能,涉及Python爬蟲相關網(wǎng)絡接口調用及json數(shù)據(jù)轉換等相關操作技巧,需要的朋友可以參考下2018-05-05python使用tqdm庫實現(xiàn)循環(huán)打印進度條
tqdm是一個用于在Python中添加進度條的庫,它可以很容易地集成到while循環(huán)中,這篇文章主要介紹了python循環(huán)打印進度條,需要的朋友可以參考下2023-05-05python計算書頁碼的統(tǒng)計數(shù)字問題實例
這篇文章主要介紹了python計算書頁碼的統(tǒng)計數(shù)字問題實例,對比2個實例講述了數(shù)字統(tǒng)計的技巧,非常實用,需要的朋友可以參考下2014-09-09