文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python实现的模板生成脚本

2023-01-31 01:59

关注

最近项目需要,针对主项目提取一个小的基础版本,供于在新建项目时使用,所以就有这个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.  查看输出目录



github: https://github.com/five3/pytmp

关于学习Python的更多文章,请扫描下方二维码。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯