python jinja2模板的使用示例
jinja2 可以用來(lái)修改配置文件,把配置文件的關(guān)鍵地方可以用變量來(lái)進(jìn)行替換
模板語(yǔ)法模板語(yǔ)法和django的模板語(yǔ)法差不多 在jinja2中,存在三種語(yǔ)法:
控制結(jié)構(gòu){% %} 變量取值{{ }} 注釋{# #} for 循環(huán){% for user in users %}{{user.username}}{% endfor %}
迭代字典
{% for key,value in my_dict.iteritems() %}{{ key }}{{ value }}{% endfor %}
過(guò)濾器常用的過(guò)濾器有:
safe: 渲染時(shí)值不轉(zhuǎn)義 capitialize: 把值的首字母轉(zhuǎn)換成大寫(xiě),其他子母轉(zhuǎn)換為小寫(xiě) lower: 把值轉(zhuǎn)換成小寫(xiě)形式 upper: 把值轉(zhuǎn)換成大寫(xiě)形式 title: 把值中每個(gè)單詞的首字母都轉(zhuǎn)換成大寫(xiě) trim: 把值的首尾空格去掉 striptags: 渲染之前把值中所有的HTML標(biāo)簽都刪掉 join: 拼接多個(gè)值為字符串 replace: 替換字符串的值 round: 默認(rèn)對(duì)數(shù)字進(jìn)行四舍五入,也可以用參數(shù)進(jìn)行控制 int: 把值轉(zhuǎn)換成整型{{ ’abc’ | catialize }}# Abc繼承和super函數(shù)
<!DOCTYPE html><html lang='en'><head> {% block head %} <link rel='stylesheet' href='http://www.leifengta.com.cn/bcjs/style.css' rel='external nofollow' /> <title>{% block title %}{% endblock %} - My Webpage</title> {% endblock %}</head><body><div id='content'>{% block content %}{% endblock %}</div><div id='footer'> {% block footer %} <script>This is javascript code </script> {% endblock %}</div></body></html>
{% extend 'base.html' %} # 繼承base.html文件 {% block title %} Dachenzi {% endblock %} # 定制title部分的內(nèi)容 {% block head %} {{ super() }} # 用于獲取原有的信息 <style type=’text/css’> .important { color: #FFFFFF } </style>{% endblock %} # 其他不修改的原封不動(dòng)的繼承利用jinja2 進(jìn)行渲染
jinja2 模塊中有一個(gè)名為Enviroment的類(lèi),這個(gè)類(lèi)的實(shí)例用于存儲(chǔ)配置和全局對(duì)象,然后從文件系統(tǒng)或其他位置中加載模板
1.基本使用方法
PackageLoader: 包加載器 FileSystemLoader: 文件系統(tǒng)加載器2.PackageLoader使用包加載器來(lái)加載文檔的最簡(jiǎn)單方式如下:
from jinja2 import PackageLoader, Environmentenv = Environment(loader=PackageLoader(’python_project’, ’templates’)) # 創(chuàng)建一個(gè)包加載器對(duì)象template = env.get_template('base.html') # 獲取一個(gè)模板文件template.render(name='daxin', age=18) PackageLoader()兩個(gè)測(cè)試為:python包的名稱(chēng),以及模板目錄名稱(chēng) get_template(): 獲取模板目錄下的某個(gè)具體文件 render(): 接受變量,對(duì)模板進(jìn)行渲染
3.FileSystemLoader
文件系統(tǒng)加載器,不需要模板文件存在某個(gè)Python包下,可以直接訪(fǎng)問(wèn)系統(tǒng)中的文件
import osfrom jinja2 import PackageLoader, Environment, FileSystemLoaderpath_dir = '/mnt/e/files'loader = FileSystemLoader(searchpath=path_dir)env = Environment(loader=loader)template = env.get_template('index.opf') # 模板文件buf = template.render(name='daxin', age=18)with open(os.path.join('path_dir', 'index.opf'), 'w' ) as fp: fp.write(buf) FileSystemLoader(): searchpath參數(shù)后面跟的是文件所在的目錄 get_template(): 獲取模板目錄下的某個(gè)具體文件 render() 接受變量,對(duì)模板進(jìn)行渲染 渲染后的內(nèi)容可以保存到配置文件中
以上就是python jinja2模板的使用示例的詳細(xì)內(nèi)容,更多關(guān)于python jinja2模板的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Docker 啟動(dòng)Redis 并設(shè)置密碼的操作2. asp文件用什么軟件編輯3. ASP新手必備的基礎(chǔ)知識(shí)4. CentOS郵箱服務(wù)器搭建系列——SMTP服務(wù)器的構(gòu)建( Postfix )5. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象6. python 實(shí)現(xiàn)有道翻譯功能7. JAVA 實(shí)現(xiàn)延遲隊(duì)列的方法8. vue限制輸入數(shù)字或者保留兩位小數(shù)實(shí)現(xiàn)9. vue+element開(kāi)發(fā)一個(gè)谷歌插件的全過(guò)程10. 利用CSS制作3D動(dòng)畫(huà)

網(wǎng)公網(wǎng)安備