echarts是百度推出的一款开源的基于JavaScript的可视化图表库,该开发库目前发展非常不错,且支持各类图形的绘制可定制程度高,Echarts绘图库同样可以与Flask结合,前台使用echart绘图库进行图形的生成与展示,后台则是Flask通过render_template方法返回一串JSON数据集,前台收到后将其应用到绘图库上,实现动态展示Web服务日志状态功能。

如下演示案例中,将分别展示运用该绘图库如何前后端交互绘制(饼状图,柱状图,折线图)这三种最基本的图形。

实现绘制饼状图: 用于模拟统计Web容器的日志数据,通过饼状图将访问状态统计出来。

前端部分/templates/index.html代码如下:

  1. <html>
  2. <head>
  3. <meta charset="UTF-8">
  4. <title>LyShark</title>
  5. <script src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
  6. <script src="https://cdn.lyshark.com/javascript/echarts/5.0.0/echarts.min.js"></script>
  7. </head>
  8. <body>
  9. <div class="panel panel-primary" style="width: 40%;height: 30%; float: left">
  10. <div class="panel-heading">
  11. <h3 class="panel-title">LyShark 网站访问状态统计</h3>
  12. </div>
  13. <div class="panel-body">
  14. <div id="main" style="width:100%; height: 300px"></div>
  15. </div>
  16. </div>
  17. </body>
  18. <script type="text/javascript" charset="UTF-8">
  19. var kv = new Array();
  20. kv = {{ data | safe }}
  21. var test = new Array();
  22. for(var logkey in kv){
  23. test.push( {value:kv[logkey], name:logkey} )
  24. }
  25. var display = function(){
  26. var main = echarts.init(document.getElementById("main"));
  27. var option = {
  28. legend: {
  29. orient: 'vertical',
  30. left: 'left',
  31. },
  32. series: [
  33. {
  34. type: 'pie',
  35. radius: '70%',
  36. center: ['50%', '50%'],
  37. detail: {formatter:'{value}'},
  38. data: test
  39. }
  40. ]
  41. };
  42. main.setOption(option,true);
  43. };
  44. display();
  45. </script>
  46. </html>

后端代码如下通过模拟render_template返回一些数据。

  1. from flask import Flask,render_template,request
  2. import json
  3. app = Flask(import_name=__name__,
  4. static_url_path='/python', # 配置静态文件的访问url前缀
  5. static_folder='static', # 配置静态文件的文件夹
  6. template_folder='templates') # 配置模板文件的文件夹
  7. def Count_Flag_And_Flow(file):
  8. list = []
  9. flag = {}
  10. with open(file) as f:
  11. contexts = f.readlines()
  12. for line in contexts:
  13. it = line.split()[8]
  14. list.append(it)
  15. list_num = set(list)
  16. for item in list_num:
  17. num = list.count(item)
  18. flag[item] = num
  19. return flag
  20. @app.route('/', methods=["GET"])
  21. def index():
  22. Address = {'226': 4, '404': 12, '200': 159, '400': 25, '102': 117, '302': 1625}
  23. # Address = Count_Flag_And_Flow("d://access_log")
  24. return render_template("index.html",data = json.dumps(Address))
  25. if __name__ == '__main__':
  26. app.run(host="127.0.0.1", port=80, debug=False)

运行后访问自定义域名,输出如下效果的饼状图:

实现绘制柱状图: 统计访问了本站的所有ID地址并将地址数大于2的全部显示出来.

前端index.html代码如下

  1. <html>
  2. <head>
  3. <meta charset="UTF-8">
  4. <title>LyShark</title>
  5. <script src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
  6. <script src="https://cdn.lyshark.com/javascript/echarts/5.0.0/echarts.min.js"></script>
  7. </head>
  8. <body>
  9. <div class="panel panel-primary" style="width: 58%;height: 30%; float: left">
  10. <div class="panel-heading">
  11. <h3 class="panel-title">LyShark 网站设备类型统计</h3>
  12. </div>
  13. <div class="panel-body">
  14. <div id="main1" style="width:100%; height: 300px"></div>
  15. </div>
  16. </div>
  17. </body>
  18. <script type="text/javascript" charset="UTF-8">
  19. var kv = new Array();
  20. var keys = new Array();
  21. var values = new Array();
  22. kv = {{ data | safe }}
  23. for(var logkey in kv){
  24. keys.push(logkey);
  25. values.push(kv[logkey]);
  26. }
  27. var display = function() {
  28. var main1 = echarts.init(document.getElementById("main1"));
  29. var option = {
  30. xAxis: {
  31. type: 'category',
  32. data: keys
  33. },
  34. yAxis: {
  35. type: 'value'
  36. },
  37. series: [{
  38. data: values,
  39. type: 'bar'
  40. }]
  41. };
  42. main1.setOption(option,true);
  43. };
  44. display();
  45. </script>
  46. </html>

后端代码如下,路由曾则只保留一个index映射

  1. from flask import Flask,render_template,request
  2. import json
  3. app = Flask(import_name=__name__,
  4. static_url_path='/python', # 配置静态文件的访问url前缀
  5. static_folder='static', # 配置静态文件的文件夹
  6. template_folder='templates') # 配置模板文件的文件夹
  7. def Count_Flag_And_Type(file):
  8. list = []
  9. flag = {}
  10. with open(file) as f:
  11. contexts = f.readlines()
  12. for line in contexts:
  13. addr = line.split()[0].replace("(","").replace(")","")
  14. if addr != "::1":
  15. list.append(addr)
  16. # 去重并将其转为字典
  17. list_num = set(list)
  18. for item in list_num:
  19. num = list.count(item)
  20. # 如果地址只有一次则忽略
  21. if num > 1:
  22. flag[item] = num
  23. return flag
  24. @app.route('/', methods=["GET"])
  25. def index():
  26. Types = {'Linux': 23, 'studies': 57, 'Windows': 87, 'compatible': 44, 'web': 32, 'X11': 78}
  27. # Types = Count_Flag_And_Type("d://access_log")
  28. return render_template("index.html",data = json.dumps(Types))
  29. if __name__ == '__main__':
  30. app.run(host="127.0.0.1", port=80, debug=False)

柱状图绘制效果如下:

实现绘制折线图: 统计指定的时间段内的访问流量数据.

前端index.html代码如下

  1. <html>
  2. <head>
  3. <meta charset="UTF-8">
  4. <title>LyShark</title>
  5. <script src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
  6. <script src="https://cdn.lyshark.com/javascript/echarts/5.0.0/echarts.min.js"></script>
  7. </head>
  8. <body>
  9. <div class="panel panel-primary" style="width: 100%;height: 30%; float: left">
  10. <div class="panel-heading">
  11. <h3 class="panel-title">LyShark 网站流量统计</h3>
  12. </div>
  13. <div class="panel-body">
  14. <div id="main" style="width:100%; height: 400px"></div>
  15. </div>
  16. </div>
  17. </body>
  18. <script type="text/javascript" charset="UTF-8">
  19. var kv = new Array();
  20. var keys = new Array();
  21. var values = new Array();
  22. kv = {{ data | safe }};
  23. for(var logkey in kv){
  24. keys.push(logkey);
  25. values.push(kv[logkey]);
  26. }
  27. var display = function() {
  28. var main = echarts.init(document.getElementById("main"));
  29. var option = {
  30. xAxis: {
  31. type: 'category',
  32. boundaryGap: false,
  33. data: keys
  34. },
  35. yAxis: {
  36. type: 'value'
  37. },
  38. series: [{
  39. data: values,
  40. type: 'line',
  41. areaStyle: {},
  42. }]
  43. };
  44. main.setOption(option,true);
  45. };
  46. display();
  47. </script>
  48. </html>

后端代码如下,路由曾则只保留一个index映射

  1. from flask import Flask,render_template,request
  2. import json
  3. app = Flask(import_name=__name__,
  4. static_url_path='/python', # 配置静态文件的访问url前缀
  5. static_folder='static', # 配置静态文件的文件夹
  6. template_folder='templates') # 配置模板文件的文件夹
  7. def Count_Time_And_Flow(file):
  8. times = {} # key 保存当前时间信息
  9. flow = {} # value 当前时间流量总和
  10. Count= 0 # 针对IP地址的计数器
  11. with open(file) as f:
  12. contexts = f.readlines()
  13. for line in contexts:
  14. if line.split()[9] != "-" and line.split()[9] != '"-"':
  15. size = line.split()[9]
  16. temp = line.split()[3]
  17. ip_attr = temp.split(":")[1] + ":" + temp.split(":")[2]
  18. Count = int(size) + Count
  19. if ip_attr in times.keys():
  20. flow[ip_attr] = flow[ip_attr] + int(size)
  21. else:
  22. times[ip_attr] = 1
  23. flow[ip_attr] = int(size)
  24. return flow
  25. @app.route('/', methods=["GET"])
  26. def index():
  27. OutFlow = {'03:30': 12, '03:48': 25, '04:15': 47, '04:28': 89, '04:42': 66, '04:51': 54}
  28. # OutFlow = Count_Time_And_Flow("d://access_log")
  29. return render_template("index.html",data = json.dumps(OutFlow))
  30. if __name__ == '__main__':
  31. app.run(host="127.0.0.1", port=80, debug=False)

折现图绘制效果如下:

如上是三种常用图形的绘制方式,其他图形同理可以参考如上方代码中的写法,我们可以将这三个图形合并在一起,主要是前端对其进行排版即可。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <link rel="stylesheet" href="https://cdn.lyshark.com/javascript/bootstrap/3.3.7/css/bootstrap.min.css">
  6. <script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
  7. <script type="text/javascript" src="https://cdn.lyshark.com/javascript/echarts/5.0.0/echarts.min.js"></script>
  8. </head>
  9. <body>
  10. <!--饼状图绘制方法-->
  11. <div class="panel panel-primary" style="width: 40%;height: 30%;float: left">
  12. <div class="panel-heading">
  13. <h3 class="panel-title">饼状图绘制</h3>
  14. </div>
  15. <div class="panel-body">
  16. <div id="PieChart" style="width:100%; height: 300px"></div>
  17. </div>
  18. </div>
  19. <!--柱状图绘制方法-->
  20. <div class="panel panel-primary" style="width: 58%;height: 30%; float: right">
  21. <div class="panel-heading">
  22. <h3 class="panel-title">柱状图绘制</h3>
  23. </div>
  24. <div class="panel-body">
  25. <div id="HistogramChart" style="width:100%; height: 300px"></div>
  26. </div>
  27. </div>
  28. <!--折线图绘制方法-->
  29. <div class="panel panel-primary" style="width: 100%;height: 40%; float: left">
  30. <div class="panel-heading">
  31. <h3 class="panel-title">折线图绘制</h3>
  32. </div>
  33. <div class="panel-body">
  34. <div id="Linechart" style="width:100%; height: 460px"></div>
  35. </div>
  36. </div>
  37. <!--饼状图绘制方法-->
  38. <script type="text/javascript" charset="UTF-8">
  39. var kv = new Array();
  40. kv = {{ Address | safe }}
  41. var test = new Array();
  42. for(var logkey in kv){
  43. test.push( {value:kv[logkey], name:logkey} )
  44. }
  45. var display = function(){
  46. var echo = echarts.init(document.getElementById("PieChart"));
  47. var option = {
  48. legend: {
  49. orient: 'vertical',
  50. left: 'left',
  51. },
  52. series: [
  53. {
  54. type: 'pie',
  55. radius: '70%',
  56. center: ['50%', '50%'],
  57. detail: {formatter:'{value}'},
  58. data: test
  59. }
  60. ]
  61. };
  62. echo.setOption(option,true);
  63. };
  64. display();
  65. </script>
  66. <!--柱状图绘制方法-->
  67. <script type="text/javascript" charset="UTF-8">
  68. var kv = new Array();
  69. var keys = new Array();
  70. var values = new Array();
  71. kv = {{ Types | safe }}
  72. for(var logkey in kv){
  73. keys.push(logkey);
  74. values.push(kv[logkey]);
  75. }
  76. var display = function() {
  77. var echo = echarts.init(document.getElementById("HistogramChart"));
  78. var option = {
  79. tooltip: {
  80. trigger: 'axis',
  81. axisPointer: {
  82. type: 'shadow'
  83. }
  84. },
  85. grid: {
  86. left: '3%',
  87. right: '4%',
  88. bottom: '3%',
  89. containLabel: true
  90. },
  91. xAxis: {
  92. type: 'category',
  93. data: keys
  94. },
  95. yAxis: {
  96. type: 'value'
  97. },
  98. series: [{
  99. data: values,
  100. type: 'bar'
  101. }]
  102. };
  103. echo.setOption(option,true);
  104. };
  105. display();
  106. </script>
  107. <!--折线图绘制方法-->
  108. <script type="text/javascript" charset="UTF-8">
  109. // 函数主要用于将传入的字典分解成key,value格式并返回
  110. var get_key_value = function(kv)
  111. {
  112. var keys = new Array();
  113. var values = new Array();
  114. for(var logkey in kv)
  115. {
  116. keys.push(logkey);
  117. values.push(kv[logkey]);
  118. }
  119. return [keys,values];
  120. }
  121. // 输出1分钟负载
  122. var kv = new Array();
  123. kv = {{ x | safe }};
  124. var x = get_key_value(kv);
  125. // 输出5分钟负载
  126. var kv = new Array();
  127. kv = {{ y | safe }};
  128. var y = get_key_value(kv);
  129. // 输出15分钟负载
  130. var kv = new Array();
  131. kv = {{ z | safe }};
  132. var z = get_key_value(kv);
  133. // 显示利用率
  134. var display = function() {
  135. var echo = echarts.init(document.getElementById("Linechart"));
  136. var option = {
  137. title: {
  138. left: 'left',
  139. text: 'CPU 利用表',
  140. },
  141. // 调节大小
  142. grid: {
  143. left: '3%',
  144. right: '4%',
  145. bottom: '3%',
  146. containLabel: true
  147. },
  148. // tooltip 鼠标放上去之后会自动出现坐标
  149. tooltip: {
  150. trigger: 'axis',
  151. axisPointer: {
  152. type: 'cross',
  153. label: {
  154. backgroundColor: '#6a7985'
  155. }
  156. }
  157. },
  158. legend: {
  159. data: ['1分钟负载', '5分钟负载', '15分钟负载']
  160. },
  161. xAxis: {
  162. type: 'category',
  163. // data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  164. data: x[0]
  165. },
  166. yAxis: {
  167. type: 'value'
  168. },
  169. series:
  170. [
  171. {
  172. name: "1分钟负载",
  173. stack: "总量",
  174. //data: [10, 25, 99, 87, 54, 66, 2],
  175. data: x[1],
  176. type: 'line'
  177. },
  178. {
  179. name: "5分钟负载",
  180. stack: "总量",
  181. //data: [89, 57, 85, 44, 25, 4, 54],
  182. data: y[1],
  183. type: 'line'
  184. },
  185. {
  186. name: "15分钟负载",
  187. stack: "总量",
  188. //data: [1, 43, 2, 12, 5, 4, 7],
  189. data: z[1],
  190. type: 'line'
  191. }
  192. ]
  193. };
  194. echo.setOption(option,true);
  195. };
  196. display();
  197. </script>
  198. </body>

后端代码如下,其中的参数可以从数据库内提取也可以从文件中读入。

  1. from flask import Flask,render_template,request
  2. import json
  3. app = Flask(import_name=__name__,
  4. static_url_path='/python', # 配置静态文件的访问url前缀
  5. static_folder='static', # 配置静态文件的文件夹
  6. template_folder='templates') # 配置模板文件的文件夹
  7. @app.route('/', methods=["GET"])
  8. def index():
  9. Address = {'226': 4, '404': 12, '200': 159, '400': 25, '102': 117, '302': 1625}
  10. Types = {'Linux': 23, 'studies': 57, 'Windows': 87, 'compatible': 44, 'web': 32, 'X11': 78}
  11. x = {'03:30': 12, '03:48': 25, '04:15': 47, '04:28': 89, '04:42': 66, '04:51': 54}
  12. y = {'05:22': 55, '07:48': 29, '07:15': 98, '08:54': 11, '08:41': 61, '06:51': 5}
  13. z = {'07:30': 1, '09:48': 5, '06:15': 24, '08:28': 59, '2:42': 11, '08:51': 22}
  14. return render_template("index.html",Address = json.dumps(Address), Types= json.dumps(Types), x = json.dumps(x), y = json.dumps(y), z = json.dumps(z))
  15. if __name__ == '__main__':
  16. app.run(host="127.0.0.1", port=80, debug=False)

输出效果如下:

Flask 框架:运用Echarts绘制图形的更多相关文章

  1. Flask框架:运用Ajax轮询动态绘图

    Ajax是异步JavaScript和XML可用于前后端交互,在之前<Flask 框架:运用Ajax实现数据交互>简单实现了前后端交互,本章将通过Ajax轮询获取后端的数据,前台使用echa ...

  2. Flask框架:如何运用Ajax轮询动态绘图

    摘要:Ajax是异步JavaScript和XML可用于前后端交互. 本文分享自华为云社区<Flask框架:运用Ajax轮询动态绘图>,作者:LyShark. Ajax是异步JavaScri ...

  3. 使用echarts绘制条形图和扇形图

    使用echarts绘制条形图和扇形图 简单举例说明下echarts如何绘制条形图和扇形图 代码示例 <!doctype html> <html lang="en" ...

  4. 面试简历书写、Flask框架介绍与快速使用、Flask演示登录页面、用户信息页面案例

    今日内容概要 面试简历编写 Flask框架介绍与安装 内容详细 1.面试简历编写 # 千万不要几个小时把简历凑出来 几天到一周 # 有没有面试机会,取决于简历写得怎么样 简历写好是第一步 # 投简历的 ...

  5. Flask 框架入门

    Flask Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2 . 安装 Flask 依赖两个外部库, We ...

  6. CSS 魔法系列:纯 CSS 绘制图形(心形、六边形等)

    <CSS 魔法系列>继续给大家带来 CSS 在网页中以及图形绘制中的使用.这篇文章给大家带来的是纯 CSS 绘制五角星.六角形.五边形.六边形.心形等等. 我们的网页因为 CSS 而呈现千 ...

  7. html5 Canvas绘制图形入门详解

    html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生.html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox.Chrome. ...

  8. html5 canvas 笔记一(基本用法与绘制图形)

    <canvas> 元素 <canvas id="tutorial" width="150" height="150"> ...

  9. Flask框架获取用户IP地址的方法

    本文实例讲述了python使用Flask框架获取用户IP地址的方法.分享给大家供大家参考.具体如下: 下面的代码包含了html页面和python代码,非常详细,如果你正使用Flask,也可以学习一下最 ...

随机推荐

  1. cordova 发送ajax请求的相关配置

    <access origin="*" /> <preference name="scheme" value="http" ...

  2. Javaweb-JSP详解

    一.什么是JSP Java Server Pages:Java服务器端页面,和Servlet一样,用于动态web技术 最大的特点: 写JSP就像在写HTML 区别: HTML只给用户提供静态的数据 J ...

  3. 【原创】Selenium获取请求头、响应头

    本文仅供学习交流使用,如侵立删! Selenium获取请求头.响应头 操作环境 win10 . mac Python3.9 selenium.seleniumwire selenium是没有办法直接获 ...

  4. ceph 007 双向池同步 rgw对象网关配置 s3对象存储

    增量导入导出要基于快照 导出的过程当中害怕镜像被修改所以打快照.快照的数据是不会变化的 镜像级别的双向同步 镜像主到备,备到主.一对一 就算是池模式的双向同步,镜像也具有主备关系 双向同步,池模式 [ ...

  5. SpringBoot 注解简介(持续更新)

    虽然工作中交替会使用spring mvc 和spring boot 框架,但实际对spring中的很多注解并不是很了解,本篇将持续更新学习到的spring 注解. Spring 主入口类上的注解 Sp ...

  6. HTTP 的 Content-Type 及其媒体类型(MIME)

    Content-Type Content-Type 代表 HTTP 携带的文件类型,决定文件接收方或发送方将以什么形式.什么编码读取这个文件.下图,load.gif 的媒体类型就是 image/gif ...

  7. Mybatis 懒加载使用及源码分析

    Mybatis 懒加载的使用 什么是懒加载?懒加载的意思就是在使用的时候才去加载,不使用不去加载,相反的就叫饥饿加载或者立即加载.懒加载在Mybatis中一般是存在与联合查询的情况,比如查询一个对象的 ...

  8. NOI P序列题 (二分)

    题面 题解 --WQS二分 想到这个这题就完了. 赛时没想到这个你就完了. 时间复杂度 O ( n log ⁡ a ) O(n\log a) O(nloga) 不难发现这题有凸性,可以WQS二分. 我 ...

  9. 前端利器躬行记(8)——VSCode插件研发

    VSCode提供了丰富的 API,可以借助编辑器扩展许多定制功能. 本次研发了一款名为 Search Method 的插件,在此记录整个研发过程. 一.准备工作 1)安装环境 首先是全局安装 yo 和 ...

  10. 第二十八篇:关于node.js连接数据库

    好家伙,这个不难,但是也不简单. $ cnpm install mysql 教程里是带美元符的,但是我打的时候加上美元符用不了,所以我就没用美元符了,一样能行. 还有,淘宝镜像,yyds, var m ...