前言
提升工作效率的利器,如果场景需要根据一个模版,生成不一样的配置文件,如果都通过生成其实欠妥,一方面麻烦,另一方面不方便管理,如果可以用一个模版来统一管理格式,通过模版生成每个需求的配置文件,岂不美哉
随之想到jinja2这个库
jinja2使用
jinja2 是一个流行的Python模板引擎,主要用于生成文本输出,这些输出可以是HTML、XML、JSON、docker配置文件等。jinja2 使用了类似于Django模板语言的语法,但其功能更加强大和灵活。
Template 类是 jinja2 库中的一个核心组件,用于表示一个模板。
以下用两个例子快速过下应用,更多用法参考官网文档:
https://jinja.palletsprojects.com/en/3.1.x/
通过
$ pip install Jinja2
安装
2.1 直接通过string生成文件
from jinja2 import Template
# 创建一个模板字符串
template_string = """
Hello {{ name }}!
This is an example of Jinja2 template.
Today is {{ date }}.
{% if is_weekend %}
Enjoy your weekend!
{% else %}
Have a great day at work!
{% endif %}
"""
# 创建一个 Template 对象
template = Template(template_string)
# 提供模板中需要的变量
context = {
'name': 'Alice',
'date': '2023-04-01',
'is_weekend': True
}
# 渲染模板,并传入上下文变量
rendered = template.render(context)
# 输出渲染后的文本
print(rendered)
结果为

可以看出来 本身模版也有语句,可以根据输入参数来定义最终的输出文本
定义了一个包含占位符 {{ name }}、{{ date }} 和控制结构 {% if %} ... {% endif %} 的模板字符串
2.2 直接读取json文件生成配置文件
文件
{
"name": "{{NAME}}",
"age": "{{AGE}}"
}
代码
from jinja2 import Template
file_path = './demo.json'
dest_path = './demo_output.json'
with open(file_path, "r") as reader:
content = reader.read()
template = Template(content)
dest_content = template.render(NAME='woniuche',
AGE='23')
with open(dest_path, "w") as writer:
writer.write(dest_content)
输出文本

推荐阅读:
公众号:AI蜗牛车
保持谦逊、保持自律、保持进步
发送【蜗牛】获取一份《手把手AI项目》(AI蜗牛车著)
发送【1222】获取一份不错的leetcode刷题笔记
发送【AI四大名著】获取四本经典AI电子书