全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Python实现的简单模板引擎功能示例

本文实例讲述了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 


相关文章: 如何彻底删除建站之星生成的Banner?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何在Golang中使用replace替换模块_指定本地或远程路径  学校免费自助建站系统:智能生成+拖拽设计+多端适配  重庆市网站制作公司,重庆招聘网站哪个好?  如何通过云梦建站系统实现SEO快速优化?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  济南专业网站制作公司,济南信息工程学校怎么样?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  用v-html解决Vue.js渲染中html标签不被解析的问题  做企业网站制作流程,企业网站制作基本流程有哪些?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  Swift中循环语句中的转移语句 break 和 continue  如何用已有域名快速搭建网站?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  网站制作报价单模板图片,小松挖机官方网站报价?  智能起名网站制作软件有哪些,制作logo的软件?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  如何在景安服务器上快速搭建个人网站?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  如何高效完成独享虚拟主机建站?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  如何在七牛云存储上搭建网站并设置自定义域名?  常州企业网站制作公司,全国继续教育网怎么登录?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  如何破解联通资金短缺导致的基站建设难题?  高端建站如何打造兼具美学与转化的品牌官网?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  如何制作一个表白网站视频,关于勇敢表白的小标题?  定制建站流程解析:需求评估与SEO优化功能开发指南  *服务器网站为何频现安全漏洞?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  广德云建站网站建设方案与建站流程优化指南  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  如何通过wdcp面板快速创建网站?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  如何用PHP快速搭建高效网站?分步指南  详解jQuery停止动画——stop()方法的使用  建站主机服务器选型指南与性能优化方案解析  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。