我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python实现的模板生成脚本

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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.  查看输出目录



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

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

免责声明:

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

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

python实现的模板生成脚本

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python实现的模板生成脚本

最近项目需要,针对主项目提取一个小的基础版本,供于在新建项目时使用,所以就有这个python模板生成脚本,其作用如下:1、通过配置文件来控制模板中的数据、格式化的过滤条件2、执行后会把目录下所有的文件都会执行一篇  #!/usr/bin/p
2023-01-31

利用Python脚本生成sitemap.xml的实现方法

安装lxml首先需要pip install lxml安装lxml库。如果你在ubuntu上遇到了以下错误:#include "libxml/xmlversion.h" compilation terminated. error: comma
2022-06-04

如何实现Python脚本生成命令行

这篇文章主要讲解了“如何实现Python脚本生成命令行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现Python脚本生成命令行”吧!有时候我们会有这样的一个需求:我们定义了一个 Py
2023-06-30

python脚本实现xls(xlsx)转成csv

# xls_csv 把xls,xlsx格式的文档转换成csv格式 # 使用 python xls2csv.py # -*- coding: utf-8 -*- import xlrd impor
2022-06-04

C++ 函数模板的实例化和生成

函数模板实例化允许在调用时针对不同类型生成特定类型的函数实现。编译器自动执行实例化,但也可以显式生成。函数模板提供了比较不同类型对象的能力,例如比较int和string。C++ 函数模板的实例化和生成函数模板是一种强大的 C++ 特性,它
C++ 函数模板的实例化和生成
2024-04-14

Shell脚本实现生成SSL自签署证书

启用 apache 的 mod_ssl 之后需要有证书才能正常运作。写了个脚本来操作。首先要确定机器上已经有 openssl 。#!/bin/sh# # ssl 证书输出的根目录。sslOutputRoot="/etc/apache_ssl
2022-06-04

Shell脚本实现批量生成nagios配置文件

如果管理的站点和服务器较多的情况下,每次修改配置文件都相当痛苦。因而想到了用shell脚本来批量生成配置文件和配置数据。下面这个脚本是为了批量生成nagios监控配置文件的一个shell脚本程序。其原理是事先定义一个shell脚本模板,然后
2022-06-04

shell脚本怎么实现快速生成xml格式

这篇文章主要介绍“shell脚本怎么实现快速生成xml格式”,在日常操作中,相信很多人在shell脚本怎么实现快速生成xml格式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”shell脚本怎么实现快速生成xm
2023-06-09

用Python脚本生成Android SALT扰码的方法

代码如下:#!/usr/bin/python # Filename: gen_salt.py import random salt =[] for i in range(0, 30): salt.append( ra
2022-06-06

java集成itextpdf实现通过pdf模板填充数据生成pdf

文章目录 一、制作pdf模板1.1、使用excel制作一个表格1.2、转成pdf1.3、设置表单域1.4、最终模版效果 二、引入POM依赖三、代码实现3.1、工具类3.2、实体对象3.3、Controller 一、制作
2023-08-18

python脚本框架webpy模板赋值的示例分析

这篇文章主要为大家展示了“python脚本框架webpy模板赋值的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python脚本框架webpy模板赋值的示例分析”这篇文章吧。注意:ind
2023-06-25

shell脚本实现随机生成10个8位密码

随机生成10个8位密码shell脚本 1.首位大写字母 2.中间六位大小写字母数字随机混合 3.第八位[0-9]#!/bin.bash for i in {1..10} do A=`head -c 500 /dev/urandom | tr
2022-06-04

shell脚本实现快速生成xml格式sitemap实例分享

用shell快速生成xml格式的sitemap地图文件,中小型网站适用。在本次案例中,生成12053条URL的sitemap文件,仅用时4.3秒!shell代码如下:cat sitemap.txt|awk 'BEGIN{print "
2022-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录