python - 使用 Flask 和 render_template 显示 HTML 表格

标签 python html flask pymysql

我想在使用 Google Cloud SQL 和 Google App Engine 的网站上显示表格。 我正在使用 Flask 和 pymysql。为了显示查询结果,我使用 Flask 的 render_template。

我已经在这里找到了其他类似的主题(例如 Topic: Listing table results to HTML with Flask ),但在部署应用程序时仍然收到错误。看来该错误与 for 循环有关。错误显示“jinja2.exceptions.TemplateSyntaxError:需要标记名称”。

这是我收到的完整错误消息:

ERROR in app: Exception on /analysis [GET]
Traceback (most recent call last):    File "/env/lib/python3.7/site-packages/flask/app.py", line 2292, in wsgi_app      response = self.full_dispatch_request()
File "/env/lib/python3.7/site-packages/flask/app.py", line 1815, in full_dispatch_request      rv = self.handle_user_exception(e)
File "/env/lib/python3.7/site-packages/flask/app.py", line 1718, in handle_user_exception      reraise(exc_type, exc_value, tb)
File "/env/lib/python3.7/site-packages/flask/_compat.py", line 35, in reraise      raise value
File "/env/lib/python3.7/site-packages/flask/app.py", line 1813, in full_dispatch_request      rv = self.dispatch_request()
File "/env/lib/python3.7/site-packages/flask/app.py", line 1799, in dispatch_request      return self.view_functions[rule.endpoint](**req.view_args)
File "/srv/main.py", line 61, in analysis      return render_template("analysis.html", result = result)
File "/env/lib/python3.7/site-packages/flask/templating.py", line 134, in render_template      return _render(ctx.app.jinja_env.get_or_select_template(template_name_or_list),    File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 869, in get_or_select_template      return self.get_template(template_name_or_list, parent, globals)
File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 830, in get_template      return self._load_template(name, self.make_globals(globals))
File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 804, in _load_template      template = self.loader.load(self, name, globals)
File "/env/lib/python3.7/site-packages/jinja2/loaders.py", line 125, in load      code = environment.compile(source, name, filename)
File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 591, in compile      self.handle_exception(exc_info, source_hint=source_hint)
File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 780, in handle_exception      reraise(exc_type, exc_value, tb)
File "/env/lib/python3.7/site-packages/jinja2/_compat.py", line 37, in reraise      raise value.with_traceback(tb)
File "/srv/templates/analysis.html", line 23, in template      <p class="p1"><span class="s1"><span class="Apple-tab-span"> </span>{% </span><span class="s2">for</span><span class="s1"> r </span><span class="s2">in</span><span class="s1"> result %}</span></p>
File "/env/lib/python3.7/site-packages/jinja2/environment.py", line 497, in _parse      return Parser(self, source, name, encode_filename(filename)).parse()
File "/env/lib/python3.7/site-packages/jinja2/parser.py", line 901, in parse      result = nodes.Template(self.subparse(), lineno=1)
File "/env/lib/python3.7/site-packages/jinja2/parser.py", line 883, in subparse      rv = self.parse_statement()
File "/env/lib/python3.7/site-packages/jinja2/parser.py", line 125, in parse_statement      self.fail('tag name expected', token.lineno)
File "/env/lib/python3.7/site-packages/jinja2/parser.py", line 59, in fail      raise exc(msg, lineno, self.name, self.filename)  jinja2.exceptions.TemplateSyntaxError: tag name expected

我在main.py中的代码:

    import logging
    import os
    from flask import Flask, render_template
    from flask import request
    import urllib.request
    from urllib.parse import parse_qs, urlparse
    import platform
    import pymysql
    import datetime

    db_user = os.environ.get('CLOUD_SQL_USERNAME')
    db_password = os.environ.get('CLOUD_SQL_PASSWORD')
    db_name = os.environ.get('CLOUD_SQL_DATABASE_NAME')
    db_connection_name = os.environ.get('CLOUD_SQL_CONNECTION_NAME')

    app = Flask(__name__)

    @app.route('/analysis', methods=['GET'])
    def analysis():
        if os.environ.get('GAE_ENV') == 'standard':
            unix_socket = '/cloudsql/{}'.format(db_connection_name)
            cnx = pymysql.connect(user=db_user, password=db_password,
                                  unix_socket=unix_socket, db=db_name)
        else:
            host = '127.0.0.1'
            #unix_socket = '/cloudsql/{}'.format(db_connection_name)
        cnx = pymysql.connect(user=db_user, password=db_password,
                                  unix_socket=unix_socket, db=db_name)
        with cnx.cursor() as cursor:
            sql = 'SELECT * FROM content'
            cursor.execute(sql)
            result = cursor.fetchall()
        cnx.close()
        return render_template("analysis.html", result = result)

if __name__ == '__main__':
    app.run(host='127.0.0.1', port=8080, debug=True)

文件分析.html:

<!doctype html>
<table>
<tr>
  <th>contentID</th>
  <th>timestamp</th> 
  <th>clientID</th>
  <th>content</th>
</tr>
{% for r in result %}
<tr>
  <td>{{ r[0] }}</td>
  <td>{{ r[1] }}</td> 
  <td>{{ r[2] }}</td>
  <td>{{ r[3] }}</td>
</tr>
{% endfor %}
</table>

您有什么建议我可以更改以使其正常工作吗?
提前致谢!

最佳答案

实现此目的的一种方法是首先拥有一个对象,或使用 pandas 来 read_csv,然后使用数据框的 to_html 方法。

如果您的数据格式已经正确,这可以节省大量时间:

import pandas as pd
from flask import Flask, render_template

@app.route("/table-page", methods=['GET'])
def table():

    data_dic = {
        'id': [100, 101, 102],
        'color': ['red', 'blue', 'red']}
    columns = ['id', 'color']
    index = ['a', 'b', 'c']

    df = pd.DataFrame(data_dic, columns=columns, index=index)
    table = df.to_html(index=False)
    
    return render_template(
        "at-leaderboard.html",
        table=table)

现在,您获取 HTML 字符串并将其粘贴到模板中,而无需将其作为 JSON 或需要 Jinja 模板格式化的字典发送:

<html>
  <body>
    <div>
      {{ table | safe }}
    </div>
  </body>
</html>

关于python - 使用 Flask 和 render_template 显示 HTML 表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53466062/

相关文章:

python - 为什么表达包含 '\' 的正则表达式在没有原始字符串的情况下也能工作。

python - 将 DataFrame 写入 CSV,并在 Pandas 中为行名称添加标题名称

python - 如何在 flask 网络应用程序中接受来自 Xively 的 POST 数据?

python - Flask 邮件仅发送到某些域

mysql - 从数据库表名称构建下拉列表

python - bitcoinrpc 调用不返回任何内容

javascript - 在输入框中添加数据输入掩码属性时,jquery 代码不起作用

html - 仅捕获网站客户端的一个 <div>

html - 调整浏览器大小时如何防止 div 元素移动?

python - 带spacy的名词短语