0

0

动态生成可变长度的 HTML 表格(Flask 教程)

霞舞

霞舞

发布时间:2026-02-03 23:52:02

|

694人浏览过

|

来源于php中文网

原创

动态生成可变长度的 HTML 表格(Flask 教程)

本文介绍如何在 flask 中基于数据库查询结果自动渲染任意行数的 html 表格,无需手动编写重复标签,通过 jinja2 模板引擎实现数据驱动的表格生成。

在 Web 开发中,将数据库查询结果(如 50 行、500 行甚至更多)以表格形式展示在网页上,是常见需求。手动为每行写

... 显然不可扩展,也不符合现代 Web 开发实践。Flask 内置的 Jinja2 模板引擎正是为此类动态内容而设计——它支持逻辑控制、循环与变量插值,能轻松将 Python 数据结构(如列表、字典)映射为 HTML 结构。

✅ 核心实现三步法

  1. 后端:查询数据并传入模板
    在 Flask 路由中,使用 SQLAlchemy、sqlite3 或其他数据库驱动获取数据,并以列表形式(如 list[dict])传递给模板:
from flask import Flask, render_template
import sqlite3

app = Flask(__name__)

@app.route('/')
def show_table():
    # 示例:从 SQLite 查询所有用户
    conn = sqlite3.connect('example.db')
    conn.row_factory = sqlite3.Row  # 支持按列名访问
    cur = conn.cursor()
    cur.execute("SELECT id, name, age FROM users")
    rows = [dict(row) for row in cur.fetchall()]  # 转为字典列表,便于模板使用
    conn.close()

    return render_template('table.html', rows=rows)
  1. 前端:Jinja2 模板中动态渲染表格
    在 templates/table.html 中,使用 {% for %} 循环遍历 rows,自动生成 和 。表头( )固定定义,内容区( )由数据驱动:
    
    
    
        动态用户表格
        
    
    
        

    用户数据表(共 {{ rows|length }} 条记录)

    {% if rows %} {% for row in rows %} {% endfor %} {% else %} {% endif %}
    ID 姓名 年龄
    {{ row.id }} {{ row.name | default('N/A') }} {{ row.age or '未知' }}
    暂无数据
    ? 提示:{{ row.name | default('N/A') }} 使用 Jinja2 过滤器处理可能的空值,增强健壮性;colspan="3" 确保空状态提示横跨全部列。
    1. 进阶建议(可选但推荐)
    • 分页优化:若数据量极大(如上万行),应在后端加 LIMIT/OFFSET 或使用 paginate()(SQLAlchemy),避免前端卡顿;
    • 响应式支持:为表格添加 overflow-x: auto 容器或使用 Bootstrap 表格类提升移动端体验;
    • 安全防护:Jinja2 默认转义变量输出(防止 XSS),但若需渲染 HTML 内容,请显式使用 |safe 过滤器,并确保来源可信。

    ✅ 总结

    Flask + Jinja2 的组合让「数据库 → 动态表格」变得简洁可靠:你只需关注数据获取逻辑与模板结构,无需手写千行 HTML。只要数据以标准 Python 容器(如 list[dict])形式传入,Jinja2 就能高效、安全、可读地完成渲染。这是服务端动态网页开发的标准范式,也是 Flask “轻量但完整” 设计哲学的典型体现。

    轩宇淘宝客系统
    轩宇淘宝客系统

    轩宇淘宝客是一款适用于淘宝客打折单品推广的程序,无论老手或新手都能短时间内赚取大量佣金的淘宝客网站程序,不同于现在广泛的淘宝客推广网站。本程序可手动添加商品,同时也配置强大的多功能采集插件,可采集评论,也可自定义采集规则,全自动无人值守采集更新网站,无需人工维护。默认提供精美的页面设计模版,超好的用户访问体验,超高转化率。对搜索引擎收录友好,整站伪静态技术,访问速度快,无需等待漫长的生成HTML页

    下载

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

90

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

73

2025.12.15

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

21

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

32

2026.01.06

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2023.12.07

overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1774

2024.08.15

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

362

2023.06.29

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号