主页
  • 主页
  • 分类
  • 热文
  • 教程
  • 面试
  • 标签
Python

Python 基础

Python 主页
Python 概述
Python 历史
Python 功能
Python 与 C++
Python Hello World
Python 应用领域
Python 解释器及其模式
Python 环境设置
Python 虚拟环境
Python 语法
Python 变量
Python 数据类型
Python 类型转换
Python Unicode 系统
Python 文字
Python 运算符
Python 算术运算符
Python 比较运算符
Python 赋值运算符
Python 逻辑运算符
Python 位运算符
Python 成员运算符
Python 身份运算符
Python 运算符优先级
Python 注释
Python 用户输入
Python 数字
Python 布尔值

Python 控制语句

Python 控制流
Python 决策
Python if 语句
Python if-else 语句
Python 嵌套 if 语句
Python match-case 语句
Python 循环
Python For 循环
Python for-else 循环
Python while 循环
Python break 语句
Python Continue 语句
Python pass 语句
Python 嵌套循环

Python 函数和模块

Python 函数
Python 默认参数
Python 关键字参数
Python 关键字专用参数
Python 位置参数
Python 仅限位置参数
Python 任意或可变长度参数
Python 变量作用域
Python 函数注释
Python 模块
Python 内置函数

Python 字符串

Python 字符串
Python 字符串切片
Python 字符串修改
Python 字符串连接
Python 字符串格式化
Python 转义字符
Python 字符串方法
Python 字符串练习

Python 列表

Python 列表
Python 访问列表项
Python 更改列表项
Python 添加列表项
Python 删除列表项
Python 循环列表
Python 列表推导式
Python 排序列表
Python 复制列表
Python 合并列表
Python 列表方法
Python 列表练习

Python 元组

Python 元组
Python 访问元组项
Python 更新元组
Python 解包元组项
Python 循环元组
Python 合并元组
Python 元组方法
Python 元组练习

Python 集合

Python 集合
Python 访问集合项
Python 添加集合项
Python 删除集合项
Python 循环集合
Python 合并集合
Python 复制集合
Python 集合运算符
Python 集合方法
Python 集合练习

Python 字典

Python 字典
Python 访问字典项
Python 更改字典项
Python 添加字典项
Python 移除字典项
Python 字典视图对象
Python 循环字典
Python 复制字典
Python 嵌套字典
Python 字典方法
Python 字典练习

Python 数组

Python 数组
Python 访问数组项
Python 添加数组项
Python 移除数组项
Python 循环数组
Python 复制数组
Python 反转数组
Python 排序数组
Python 合并数组
Python 数组方法
Python 数组练习

Python 文件处理

Python 文件处理
Python 文件写入
Python 文件读取
Python 重命名和删除文件
Python 目录
Python 文件方法
Python 文件/目录方法
Python OS.Path 方法

Python 面向对象编程

Python OOP 概念
Python 类和对象
Python 类属性
Python 类方法
Python 静态方法
Python 构造函数
Python 访问修饰符
Python 继承
Python 多态
Python 方法重写
Python 方法重载
Python 动态绑定
Python 动态类型
Python 抽象
Python 封装
Python 接口
Python 包
Python 内部类
Python 匿名类和对象
Python 单例类
Python 包装器类
Python 枚举
Python 反射

Python 错误和异常

Python 语法错误
Python 异常处理
Python Try-Except
Python Try-Finally
Python 抛出异常
Python 异常链
Python 嵌套 try
Python 用户定义异常
Python 日志记录
Python 断言
Python 内置异常

Python 多线程

Python 多线程
Python 线程生命周期
Python 创建线程
Python 启动线程
Python 合并线程
Python 命名线程
Python 线程调度
Python 线程池
Python 主线程
Python 线程优先级
Python 守护线程
Python 线程同步

Python 同步

Python 线程间通信
Python 死锁
Python 中断线程

Python 网络

Python 网络编程
Python 套接字编程
Python URL 处理
Python 泛型

Python 杂项

Python Date and Time
Python math模块
Python 迭代器
Python 生成器
Python 闭包
Python 装饰器
Python 递归
Python 正则表达式
Python Pip
Python 数据库访问
Python 弱引用
Python 序列化
Python 模板技术
Python 输出格式化
Python 性能测量
Python 数据压缩
Python 通用网关接口
Python XML 处理
Python 用户界面(GUI)
Python 命令行参数
Python Docstrings
Python JSON
Python 发送电子邮件
Python 进一步扩展
Python 工具/实用程序
Python GUI

Python 高级概念

Python 抽象基类
Python 自定义异常
Python 高阶函数
Python 对象的内部机制
Python 内存管理
Python 元类
Python 元编程
Python 模拟与桩
Python 猴子补丁
Python 信号处理
Python 类型提示
Python 进行自动化
Python Humanize包
Python 上下文管理器
Python 协程
Python 描述符
Python 内存泄漏
Python 不可变数据结构

基础

Python 主页
Python 概述
Python 历史
Python 功能
Python 与 C++
Python Hello World
Python 应用领域
Python 解释器及其模式
Python 环境设置
Python 虚拟环境
Python 语法
Python 变量
Python 数据类型
Python 类型转换
Python Unicode 系统
Python 文字
Python 运算符
Python 算术运算符
Python 比较运算符
Python 赋值运算符
Python 逻辑运算符
Python 位运算符
Python 成员运算符
Python 身份运算符
Python 运算符优先级
Python 注释
Python 用户输入
Python 数字
Python 布尔值

控制语句

Python 控制流
Python 决策
Python if 语句
Python if-else 语句
Python 嵌套 if 语句
Python match-case 语句
Python 循环
Python For 循环
Python for-else 循环
Python while 循环
Python break 语句
Python Continue 语句
Python pass 语句
Python 嵌套循环

函数和模块

Python 函数
Python 默认参数
Python 关键字参数
Python 关键字专用参数
Python 位置参数
Python 仅限位置参数
Python 任意或可变长度参数
Python 变量作用域
Python 函数注释
Python 模块
Python 内置函数

字符串

Python 字符串
Python 字符串切片
Python 字符串修改
Python 字符串连接
Python 字符串格式化
Python 转义字符
Python 字符串方法
Python 字符串练习

列表

Python 列表
Python 访问列表项
Python 更改列表项
Python 添加列表项
Python 删除列表项
Python 循环列表
Python 列表推导式
Python 排序列表
Python 复制列表
Python 合并列表
Python 列表方法
Python 列表练习

元组

Python 元组
Python 访问元组项
Python 更新元组
Python 解包元组项
Python 循环元组
Python 合并元组
Python 元组方法
Python 元组练习

集合

Python 集合
Python 访问集合项
Python 添加集合项
Python 删除集合项
Python 循环集合
Python 合并集合
Python 复制集合
Python 集合运算符
Python 集合方法
Python 集合练习

字典

Python 字典
Python 访问字典项
Python 更改字典项
Python 添加字典项
Python 移除字典项
Python 字典视图对象
Python 循环字典
Python 复制字典
Python 嵌套字典
Python 字典方法
Python 字典练习

数组

Python 数组
Python 访问数组项
Python 添加数组项
Python 移除数组项
Python 循环数组
Python 复制数组
Python 反转数组
Python 排序数组
Python 合并数组
Python 数组方法
Python 数组练习

文件处理

Python 文件处理
Python 文件写入
Python 文件读取
Python 重命名和删除文件
Python 目录
Python 文件方法
Python 文件/目录方法
Python OS.Path 方法

面向对象编程

Python OOP 概念
Python 类和对象
Python 类属性
Python 类方法
Python 静态方法
Python 构造函数
Python 访问修饰符
Python 继承
Python 多态
Python 方法重写
Python 方法重载
Python 动态绑定
Python 动态类型
Python 抽象
Python 封装
Python 接口
Python 包
Python 内部类
Python 匿名类和对象
Python 单例类
Python 包装器类
Python 枚举
Python 反射

错误和异常

Python 语法错误
Python 异常处理
Python Try-Except
Python Try-Finally
Python 抛出异常
Python 异常链
Python 嵌套 try
Python 用户定义异常
Python 日志记录
Python 断言
Python 内置异常

多线程

Python 多线程
Python 线程生命周期
Python 创建线程
Python 启动线程
Python 合并线程
Python 命名线程
Python 线程调度
Python 线程池
Python 主线程
Python 线程优先级
Python 守护线程
Python 线程同步

同步

Python 线程间通信
Python 死锁
Python 中断线程

网络

Python 网络编程
Python 套接字编程
Python URL 处理
Python 泛型

杂项

Python Date and Time
Python math模块
Python 迭代器
Python 生成器
Python 闭包
Python 装饰器
Python 递归
Python 正则表达式
Python Pip
Python 数据库访问
Python 弱引用
Python 序列化
Python 模板技术
Python 输出格式化
Python 性能测量
Python 数据压缩
Python 通用网关接口
Python XML 处理
Python 用户界面(GUI)
Python 命令行参数
Python Docstrings
Python JSON
Python 发送电子邮件
Python 进一步扩展
Python 工具/实用程序
Python GUI

高级概念

Python 抽象基类
Python 自定义异常
Python 高阶函数
Python 对象的内部机制
Python 内存管理
Python 元类
Python 元编程
Python 模拟与桩
Python 猴子补丁
Python 信号处理
Python 类型提示
Python 进行自动化
Python Humanize包
Python 上下文管理器
Python 协程
Python 描述符
Python 内存泄漏
Python 不可变数据结构

Python 模板技术


上一章 下一章

Python 中的模板技术是在 Web 开发中使用模板和数据动态生成静态 HTML 页面的一种技术。

在本教程中,我们将探索 Python 中模板技术的基础知识,包括安装、创建模板以及渲染带有数据的模板,重点放在 Jinja2 模板引擎上。

Python 中的字符串模板

Python 中的字符串模板是一种简单的字符串替换方式。Python 的 string 模块包含了 Template 类,提供了轻松替换字符串中占位符的实际值的方法。

string 模块中的 Template 类在 PEP 292 中描述了一种通过替换技术动态形成字符串对象的方式。其更简单的语法和功能使得它在国际化方面相比 Python 中其他的内置字符串格式化设施更容易翻译。

模板字符串使用 $ 符号进行替换,紧跟着的是符合 Python 标识符规则的标识符。

创建模板

为了创建模板,你需要使用包含以 $ 开头的占位符的字符串来实例化 Template 类,如下所示:

from string import Template

template = Template("Hello, $name!")

替换值

你可以使用 substitute() 方法来替换模板中的值,该方法接受键值对的字典。

substitute() 方法将模板中的占位符(标识符)替换成实际的值。你可以使用关键字参数或者字典来提供这些值。该方法返回一个新的字符串,其中占位符已经被填充。

示例:使用关键字参数

下面的代码使用关键字参数来替换模板字符串中的标识符:

from string import Template

tempStr = Template('Hello. My name is $name and my age is $age')
newStr = tempStr.substitute(name='Pushpa', age=26)
print(newStr)

它会产生以下输出:

Hello. My name is Pushpa and my age is 26

示例:使用字典

在下面的例子中,我们使用字典对象来映射模板字符串中的替换标识符:

from string import Template

tempStr = Template('Hello. My name is $name and my age is $age')
dct = {'name': 'Pushpalata', 'age': 25}
newStr = tempStr.substitute(dct)
print(newStr)

以上代码的输出如下:

Hello. My name is Pushpalata and my age is 25

示例:缺少参数会引发 KeyError

如果 substitute() 方法没有提供足够的参数来匹配模板字符串中的标识符,Python 会抛出 KeyError:

from string import Template

tempStr = Template('Hello. My name is $name and my age is $age')
dct = {'name': 'Pushpalata'}
newStr = tempStr.substitute(dct)
print(newStr)

产生的错误信息如下:

Traceback (most recent call last):
File "/home/cg/root/667e441d9ebd5/main.py", line 5, in <module>
newStr = tempStr.substitute(dct)
File "/usr/lib/python3.10/string.py", line 121, in substitute
return self.pattern.sub(convert, self.template)
File "/usr/lib/python3.10/string.py", line 114, in convert
return str(mapping[named])
KeyError: 'age'

使用 safe_substitute() 方法替换值

safe_substitute() 方法的行为类似于 substitute() 方法,唯一的区别是如果提供的键不足或不匹配时,它不会抛出错误。相反,原始的占位符会保留在结果字符串中不变。

示例

在下面的例子中,我们使用 safe_substitue() 方法来替换值:

from string import Template

tempStr = Template('Hello. My name is $name and my age is $age')
dct = {'name': 'Pushpalata'}
newStr = tempStr.safe_substitute(dct)
print(newStr)

它会产生以下输出:

Hello. My name is Pushpalata and my age is $age

安装 Jinja2

为了在 Python 中使用 Jinja2 进行模板化,首先需要安装该库。Jinja2 是一个强大的模板引擎,在 Web 开发中广泛用于渲染 HTML。使用 pip,Python 的包管理器,可以轻松安装它:

pip install jinja2

创建和渲染 Jinja2 模板

Jinja2 是一个功能强大的 Python 模板引擎,允许你通过混合静态模板文件与数据来创建动态内容。此部分探讨如何创建 Jinja2 模板并渲染它们。

创建 Jinja2 模板

为了创建 Jinja2 模板,你需要定义一个模板字符串或从文件中加载它。模板使用双花括号 {{ ... }} 作为占位符,并支持使用 {% ... %} 的控制结构,如循环和条件语句。

示例

以下是一个简单的 Jinja2 模板,存储在名为 "template.html" 的文件中:

<!DOCTYPE html>
<html>
<head>
    <title>Hello, {{ name }}!</title>
</head>
<body>
    <h1>Hello, {{ name }}!</h1>
    <p>Welcome to our site.</p>
</body>
</html>

渲染 Jinja2 模板

为了渲染一个 Jinja2 模板,遵循以下步骤:

  • 加载模板 —— 从文件或字符串中加载模板。
  • 创建模板对象 —— 使用 jinja2.Template 创建模板对象。
  • 渲染 —— 使用模板对象上的 render() 方法,传入作为参数或字典的数据。

示例

在这里,我们正在渲染 Jinja2 模板:

from jinja2 import Template, FileSystemLoader, Environment

# 从文件中加载模板 (template.html)
file_loader = FileSystemLoader('.')
env = Environment(loader=file_loader)
template = env.get_template('template.html')

# 使用数据渲染模板
output = template.render(name='Alice')

# 输出渲染后的模板
print(output)

渲染后的 Jinja2 模板的输出将是一个 HTML 文档,其中模板中的占位符被渲染时传入的实际数据替换:

<!DOCTYPE html>
<html>
<head>
    <title>Hello, Alice!</title>
</head>
<body>
    <h1>Hello, Alice!</h1>
    <p>Welcome to our site.</p>
</body>
</html>

高级 Jinja2 功能

Jinja2 支持各种高级特性,如循环、条件判断和自定义过滤器,使其成为创建复杂模板的强大工具。

模板继承

Jinja2 支持模板继承,允许你在基础模板中定义常见元素(比如头部、尾部、导航栏),并在子模板中扩展或覆盖特定的区块。这促进了大型项目中的代码复用和维护性。

示例

这个命名为 "base.html" 的 HTML 模板文件使用 Jinja2 模板语法定义了一个网页的基本结构。

它包含可以被派生模板覆盖的区块 "{% block title %}" 和 "{% block content %}",分别用来定制页面的标题和主要内容:

<!-- base.html -->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{% block title %}Default Title{% endblock %}</title>
</head>
<body>
    {% block content %}{% endblock %}
</body>
</html>

下面这个 Jinja2 模板文件 "child.html" 继承了 "base.html" 模板,并覆盖了标题区块,将其设置为 "Child Page",同时覆盖了内容区块,包含了带有文本 "Child Page Content" 的 <h1> 标签:

<!-- child.html -->
{% extends "base.html" %}

{% block title %}Child Page{% endblock %}

{% block content %}
<h1>Child Page Content</h1>
{% endblock %}

循环

Jinja2 允许你使用 {% for %} 循环遍历列表或其他可迭代对象。以下是一个示例,展示了如何使用循环生成 HTML 中的无序列表(<ul>):

<ul>
{% for item in items %}
    <li>{{ item }}</li>
{% endfor %}
</ul>

条件判断

Jinja2 中的条件语句({% if %} 和 {% else %})用于根据条件控制模板的流程。以下是一个示例,其中检查用户是否存在,并在存在时显示个性化问候,否则提示登录:

{% if user %}
    <p>Welcome, {{ user }}!</p>
{% else %}
    <p>Please log in.</p>
{% endif %}

自定义过滤器

Jinja2 中的自定义过滤器用于定义你自己的过滤器来在显示前处理数据。

在下面的例子中,定义了一个名为 reverse 的自定义过滤器来反转字符串 "hello",在模板中应用时结果为 "olleh":

# 定义一个自定义过滤器函数
def reverse_string(s):
    return s[::-1]

# 将过滤器注册到 Jinja2 环境中
env.filters['reverse'] = reverse_string

在模板中,你可以将 reverse 过滤器应用到任何字符串上:

{{ "hello" | reverse }}

产生的输出如下:

olleh
上一章 下一章
阅读号二维码

关注阅读号

联系二维码

联系我们

© 2024 Yoagoa. All rights reserved.

粤ICP备18007391号

站点地图