Python实现的简单模板引擎功能示例
发布时间 - 2026-01-11 03:04:33 点击率:次本文实例讲述了Python实现的简单模板引擎功能。分享给大家供大家参考,具体如下:
#coding:utf- 8
__author__="sdm"
__author_email='sdmzhu3@gmail.com'
__date__ ="$2009-8-25 21:04:13$"
'' '
pytpl 类似 php的模板类
'' '
import sys
import StringIO
import os.path
import os
#模 板的缓存
_tpl_cache={}
class Pytpl:
def __init__(self,tpl_path='./' ):
self.tpl_path=tpl_path
self.data={}
self.output = StringIO.StringIO()
pass
def set(self,name,value):
'' '
设 置模板变量
'' '
self.data[name]=value;
pass
def get(self,name):
'' '
得 到模板变量
'' '
t={}
return t.get(name, '' )
pass
def tpl(self,tplname):
'' '
渲 染模板
'' '
f=self.tpl_path+tplname
if not os.path.exists(f):
raise Exception('tpl:[%s] is not exists' % f)
mtime=os.stat(f).st_mtime
if not _tpl_cache.has_key(f) or _tpl_cache[f][ 'time' ]<mtime:
src_code=self.__compile__(open(f).read())
try :
t=open(f+'.py' , 'w' )
t.write(src_code)
t.close()
except:
pass
py_code=compile(src_code, f+'.py' , 'exec' )
_tpl_cache[f]={'code' :py_code, 'time' :mtime}
else :
py_code= _tpl_cache[f]['code' ]
exec(py_code, {'self' :self}, self.data)
return self.output.getvalue()
def execute(self,code,data,tplname):
'' '
执 行这个模板
'' '
py_file_name=tplname+'.py'
f=open(py_file_name,'w' )
f.write(code)
f.close()
execfile(py_file_name, {'self' :self}, data)
def __compile__ (self,code):
'' '
编 译模板
查找 <?标记
'' '
tlen=len(code);
flag_start='<?'
flag_end='?>'
# 默认普通标记
status=0
i=0
#分块 标记
pos_end=0
pos_start=0
#缩 进
global indent
indent=0
py_code=[]
def place_t_code(c,t_indent):
'' '
基 本的代码处理
'' '
global indent
if (c[ 0 ]== '=' ):
return ( ' ' * 4 *indent) + 'echo ( /'%s/' % (' +c[ 1 :]+ '))'
lines=c.split("/n" )
t=[]
for i in lines:
indent2=indent
tmp=i.strip(" /n/r" )
c=tmp[len(tmp)-1 :len(tmp)]
# 判定最后一个字符
if (c== '{' ):
indent+=1
tmp=tmp[0 :len(tmp)- 1 ]+ ":"
elif(c=='}' ):
indent-=1
tmp=tmp[0 :len(tmp)- 1 ]
t.append((' ' * 4 *indent2) +tmp )
return "/n" .join(t)
while 1 :
if i>=tlen: break
c=code[i];
if status== 0 :
# 编译加速
pos_start=code.find(flag_start,pos_end);
if (pos_start>- 1 ):
s=code[pos_end:pos_start]
t_code= 'echo ( ' +repr(s)+ ')'
t_code=' ' *indent* 4 +t_code
if s:
py_code.append(t_code)
i=pos_start
last_pos=i
# 进入代码状态
status=1
continue
else :
# 没有没有找到
pos_start=tlen
t_code='echo ( ' +repr(code[pos_end:pos_start])+ ' ) '
t_code=' ' *indent* 4 +t_code
py_code.append(t_code)
break
if status== 1 :
# 查找结束标记
pos_end=code.find(flag_end,i)
if (pos_end>- 1 ):
# 需要跳过<? 这个标记
t_code=place_t_code(code[pos_start+2 :pos_end],indent)
# 跳过?>结束标记
pos_end+=2
py_code.append(t_code)
else :
# 没查找到直接结束
pos_end=tlen
# 需要跳过<? 这个标记
t_code=place_t_code(code[pos_start+2 :pos_end],indent)
py_code.append(t_code)
break
status=0
i=pos_end
pass
i+=1
py_code_str="#coding:utf-8/nimport sys;global echo;echo=self.output.write/n"
py_code_str+="/n" .join(py_code)
py_code_str=py_code_str.replace("/t" , " " )
return py_code_str
def test():
tpl=Pytpl('./' );
tpl.set('title' , '标题3' )
print tpl.tpl('test.html' )
pass
if __name__ == "__main__" :
test()
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
# Python
# 模板引擎
# Python 模板引擎的注入问题分析
# Python的Flask框架标配模板引擎Jinja2的使用教程
# 深入解析Python的Tornado框架中内置的模板引擎
# 为Python的Tornado框架配置使用Jinja2模板引擎的方法
# Python的Flask框架中的Jinja2模板引擎学习教程
# Python Web开发模板引擎优缺点总结
# 如何用python写个模板引擎
# 跳过
# 进阶
# 相关内容
# 感兴趣
# 数据结构
# 给大家
# 没有找到
# 更多关于
# 所述
# 程序设计
# 使用技巧
# 操作技巧
# 讲述了
# data
# tpl_path
# set
# pass
# output
# path
# os
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何在局域网内绑定自建网站域名?
Laravel如何处理异常和错误?(Handler示例)
jquery插件bootstrapValidator表单验证详解
JavaScript如何实现类型判断_typeof和instanceof有什么区别
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
iOS发送验证码倒计时应用
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
如何用AWS免费套餐快速搭建高效网站?
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
简单实现jsp分页
Swift开发中switch语句值绑定模式
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
Laravel如何使用withoutEvents方法临时禁用模型事件
中国移动官方网站首页入口 中国移动官网网页登录
Android okhttputils现在进度显示实例代码
用v-html解决Vue.js渲染中html标签不被解析的问题
历史网站制作软件,华为如何找回被删除的网站?
Laravel如何实现API速率限制?(Rate Limiting教程)
Laravel如何使用.env文件管理环境变量?(最佳实践)
如何快速打造个性化非模板自助建站?
晋江文学城电脑版官网 晋江文学城网页版直接进入
高性价比服务器租赁——企业级配置与24小时运维服务
如何用低价快速搭建高质量网站?
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
微信小程序 wx.uploadFile无法上传解决办法
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
北京的网站制作公司有哪些,哪个视频网站最好?
Win11怎样安装网易有道词典_Win11安装词典教程【步骤】
韩国服务器如何优化跨境访问实现高效连接?
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
如何用AI帮你把自己的生活经历写成一个有趣的故事?
Laravel如何生成URL和重定向?(路由助手函数)
JavaScript如何实现路由_前端路由原理是什么
Laravel如何处理和验证JSON类型的数据库字段
jQuery中的100个技巧汇总
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何在Windows 2008云服务器安全搭建网站?
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Android GridView 滑动条设置一直显示状态(推荐)
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
Laravel用户密码怎么加密_Laravel Hash门面使用教程
HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
音乐网站服务器如何优化API响应速度?
南京网站制作费用,南京远驱官方网站?
如何用西部建站助手快速创建专业网站?

