十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章给大家分享的是有关如何使用python实现模板生成脚本的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联公司是一家集网站建设,瓦房店企业网站建设,瓦房店品牌网站建设,网站定制,瓦房店网站建设报价,网络营销,网络优化,瓦房店网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。最近项目需要,针对主项目提取一个小的基础版本,供于在新建项目时使用,所以就有这个python模板生成脚本,其作用如下:
1、通过配置文件来控制模板中的数据、格式化的过滤条件
2、执行后会把目录下所有的文件都会执行一篇
#!/usr/bin/python #encoding: utf-8 import json import codecs import os def get_files(root_path): for dir in os.walk(root_path): if dir[2]: for nf in dir[2]: yield os.path.join(dir[0], nf) def exclude_filter(exclude, nfile): files_path = exclude.get('file_path') files_name = exclude.get('file_name') base_name = os.path.basename(nfile) exts_name = exclude.get('ext_name') base_ext_name = base_name.rsplit(".", 1)[1] if files_path: for npath in files_path: if npath==nfile: return True elif files_name: for name in files_name: print name, base_name if name==base_name: return True elif exts_name: for name in exts_name: print name, base_ext_name if name==base_ext_name: return True def include_filter(include, nfile): files_path = include.get('file_path') files_name = include.get('file_name') base_name = os.path.basename(nfile) if files_path: for npath in files_path: if npath==nfile: return True elif files_name: for name in files_name: if name==base_name: return True def main(): # read config config = {} with codecs.open("config.json","rb","UTF-8") as f: config = json.loads(f.read()) if not config: return template = config.get("template") if template and template.get('path'): root_path = template.get('path') if not os.path.exists(root_path): print "source path not exist" return root_path = os.path.abspath(root_path) old_path = os.path.dirname(root_path) else: return exclude = template.get('exclude') include = template.get('include') store = config.get("store") if not store or not os.path.exists(store.get('dir_path', '')): return data = config.get("data") if not data: return if not os.path.exists(root_path): print 'root path not exists' return if os.path.isfile(root_path): files = [root_path] else: base_name = os.path.basename(root_path) store_root_path = os.path.join(store.get('dir_path'), base_name) if not os.path.exists(store_root_path): os.mkdir(store_root_path) files = get_files(root_path) for nfile in files: print nfile try: with codecs.open(nfile, "rb", "UTF-8") as f: s = f.read() if not exclude_filter(exclude, nfile) or include_filter(include, nfile): s = s % data except: with codecs.open(nfile, "rb") as f: s = f.read() # save to file fn = nfile.replace(old_path, store.get('dir_path')) fn_dir = os.path.dirname(fn) if not os.path.exists(fn_dir): os.makedirs(fn_dir) try: with codecs.open(fn, "wb", "UTF-8") as f: f.write(s) f.flush() except: with codecs.open(fn, "wb") as f: f.write(s) f.flush() if __name__ == '__main__': main()
配置文件:
{ "template": { "path" : "D:/tunicorn-web/framework-template", ##模板文件主目录 "exclude" : { ##不进行模板格式化的文件 "file_path" : [], "file_name" : ["config.json", "make_project.py"], "ext_name" : ["css", "woff2"], "file_type" : [], "regex" : [] }, "include" : { ##进行模板格式化的文件 "file_path" : [], "file_name" : [] } }, "store":{ "dir_path" : "e:/test" ##输出路径主目录 "data" : { "project_name":"NewJAVA", ##模板数据 "project_prefix":"newjava" ##模板数据 } }
执行操作:
1、安装了python环境
2、双击python脚本
3、然后在执行下README中的步骤
readme:
README
=============
脚本使用
-------------
1. 打开config.json文件
2. 配置相关信息[输出目录、项目名称、项目前缀]
3. 执行make_project.py脚本
4. 查看输出目录
感谢各位的阅读!关于“如何使用python实现模板生成脚本”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!