pyecharts結(jié)合flask框架的使用
介紹
本文主要介紹如何在Flask框架中使用pyecharts,關(guān)于Flask框架使用這里不做具體說明~
Flask模板渲染
首先需要創(chuàng)建一個flask項目,flask項目對目錄結(jié)構(gòu)要求不高,但是如果是前后端混合項目的話,模板文件必須存放在templates文件夾下,否則視圖函數(shù)返回模板文件時會提示找不到對應(yīng)的文件。下面是flask項目的簡單目錄結(jié)構(gòu):
. ├── 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="我是副標(biāo)題"))
)
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 即可訪問服務(wù),具體效果如下圖所示:

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服務(wù)以及pyecharts生成圖表,目錄結(jié)構(gòu)和模板渲染一致,這里需要注意一個問題,目前由于 json 數(shù)據(jù)類型的問題,無法將 pyecharts 中的 JSCode 類型的數(shù)據(jù)轉(zhuǎn)換成 json 數(shù)據(jù)格式返回到前端頁面中使用。因此在使用前后端分離的情況下盡量避免使用 JSCode 進(jìn)行畫圖。
下面是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="我是副標(biāo)題"))
)
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 即可訪問服務(wù)。
總結(jié)
兩篇文章只是介紹了pyecharts模塊的一些簡單使用,在官方文檔中還有很多進(jìn)階使用,經(jīng)常進(jìn)行圖表分析的開發(fā)人員們可以參考官方文檔進(jìn)行學(xué)習(xí)。
到此這篇關(guān)于pyecharts結(jié)合flask框架的使用的文章就介紹到這了,更多相關(guān)pyecharts flask框架內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pandas讀取MySQL數(shù)據(jù)到DataFrame的方法
今天小編就為大家分享一篇Pandas讀取MySQL數(shù)據(jù)到DataFrame的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
基于Numpy.convolve使用Python實現(xiàn)滑動平均濾波的思路詳解
這篇文章主要介紹了Python極簡實現(xiàn)滑動平均濾波(基于Numpy.convolve)的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05
pytorch和tensorflow計算Flops和params的詳細(xì)過程
這篇文章主要介紹了pytorch和tensorflow計算Flops和params,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
使用Python實現(xiàn)火車票查詢系統(tǒng)(帶界面)
周末、假期來了,七夕也快到了,又到一年中最一票難求的時候了!本文將用Python制作一個簡單的火車票查詢系統(tǒng),感興趣的可以了解一下2022-07-07

