当前位置:   article > 正文

Python flask + Mysql +Echarts 绘制词云图(笔记)_echarts 词云图 flask

echarts 词云图 flask

目录

步骤一:建立Myslq数据库连接

 步骤二:开发Flask应用

步骤三:创建前端页面(ciyun.html )

 步骤四:运行Flask应用并查看词云图


步骤一:建立Myslq数据库连接

  1. import json
  2. import pymysql
  3. class Mysql(object):
  4. # 创建 Mysql 类的实例时自动调用
  5. def __init__(self):
  6. # 建立MySQL数据库连接
  7. self.conn = pymysql.connect(host='localhost', user='root', password='1234', database='Design', charset="utf8")
  8. # 创建了一个游标对象cursor,用于执行SQL命令
  9. self.cursor = self.conn.cursor()
  10. # 这个方法使得 Mysql 类的实例可以作为上下文管理器使用
  11. def __enter__(self):
  12. return self
  13. # 负责关闭游标和数据库连接
  14. def __exit__(self, exc_type, exc_val, exc_tb):
  15. self.cursor.close()
  16. self.conn.close()
  17. # 返回的结果是一个元组列表,每个元组代表NameWordCount表中的一行数据。
  18. def get_word_count(self):
  19. sql = 'select word,count from NameWordCount order by count desc limit 400;'
  20. self.cursor.execute(sql)
  21. return self.cursor.fetchall()

 步骤二:开发Flask应用

这段代码是一个使用Flask框架编写的简单Web应用程序。这个Web应用程序提供了一个界面来展示词云,并且通过POST请求返回了词频统计的JSON数据,这些数据是用于生成词云的。

  1. from flask import Flask, send_from_directory, jsonify
  2. from flask import render_template
  3. from mysql import Mysql
  4. app = Flask(__name__)
  5. @app.route('/ciyun')
  6. def getdata():
  7. # 使用 render_template 函数渲染 ciyun.html 模板
  8. return render_template('ciyun.html')
  9. @app.route('/data', methods=['POST'])
  10. def myciyun():
  11. # 创建了一个 Mysql 类的实例,用于与MySQL数据库建立连接。
  12. db = Mysql()
  13. # 调用 db.house() 方法,执行SQL查询并获取结果。
  14. item = db.get_word_count()
  15. word = []
  16. count = []
  17. for data in item:
  18. word.append(data[0])
  19. count.append(data[1])
  20. return jsonify(word=word, count=count)
  21. if __name__ == '__main__':
  22. app.run(debug=True) #debug=True发生错误时会返回发生错误的地方

步骤三:创建前端页面(ciyun.html )

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>数据可视化</title>
  6. <script src="/static/js/echarts.min.js"></script>
  7. <script src="/static/jquery.min.js"></script>
  8. <script src="/static/echarts-wordcloud.min.js"></script>
  9. </head>
  10. <body>
  11. <div id="main" style="width:100%;height: 800px;border: 1px solid black"></div>
  12. <script type="text/javascript">
  13. var myChart = echarts.init(document.getElementById('main'));
  14. var app={
  15. word1:[],
  16. count1:[]
  17. };
  18. $(document).ready(function () {
  19. getData();
  20. });
  21. function getData() {
  22. $.ajax({
  23. url: '/data',
  24. data: {},
  25. type: 'POST',
  26. async: false,
  27. dataType: 'json',
  28. success: function (data) {
  29. app.word1 = data.word;
  30. app.count1 = data.count;
  31. }
  32. });
  33. }
  34. getData();
  35. var word=[];
  36. for(var i = 0;i<app.word1.length;i++){
  37. word.push({
  38. name:app.word1[i],
  39. value: app.count1[i]
  40. })
  41. }
  42. var pic = {
  43. //china图片
  44. image: ""
  45. }
  46. var maskImage = new Image();
  47. maskImage.src = pic.image
  48. option = {
  49. title: {
  50. text: '房源名称词云图',
  51. x: 'center',
  52. textStyle: {
  53. fontSize: 25
  54. }
  55. },
  56. backgroundColor: '#F7F7F7',
  57. tooltip: {
  58. show: true
  59. },
  60. series: [{
  61. type: 'wordCloud',
  62. <!-- 要绘制的“云”的形状。可用的形状有(circle)圆形(默认)、(cardioid)心形,(diamond)菱形,(triangle-forward)三角形向前,(triangle)三角形,(pentagon)五边形和(star)星形。*/-->
  63. <!-- shape: 'pentagon',-->
  64. <!-- 通过一个轮廓图像,来自定义词云的形状(白色区域将被排除在绘制文本之外)-->
  65. maskImage: maskImage,
  66. <!-- 词云的文字字号范围-->
  67. sizeRange: [10, 70],
  68. width:750,
  69. height:800,
  70. textStyle: {
  71. fontFamily: 'sans-serif',
  72. fontWeight: 'bold',
  73. color: function () {
  74. // Random color
  75. return 'rgb(' + [
  76. Math.round(Math.random() * 160),
  77. Math.round(Math.random() * 160),
  78. Math.round(Math.random() * 160)
  79. ].join(',') + ')';
  80. }
  81. },
  82. emphasis: {
  83. focus: 'self',
  84. textStyle: {
  85. textShadowBlur: 10,
  86. textShadowColor: '#333'
  87. }
  88. },
  89. data: word
  90. }]
  91. };
  92. myChart.setOption(option);
  93. //随着屏幕大小调节图表
  94. window.addEventListener("resize", () => {
  95. myChart.resize();
  96. });
  97. </script>
  98. </body>
  99. </html>

 步骤四:运行Flask应用并查看词云图

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/286668
推荐阅读
相关标签
  

闽ICP备14008679号