iOS 文件前缀一键批量修改

批量修改文件前缀,同时可更新引用文件中的前缀和环境配置中的引用。

import os
import sys
import re

# XY_ : 枚举值前缀
# XYY_ : 文件名前缀
# XYX_ : SDK暴露的头文件名前缀
# XYM_ : 用户登陆、内购、订单信息模型
 
# 第一步,要更改前缀是XY_文件的为XYY_前缀。
# 第二步,更改SDK暴露接口文件的前缀(XYX_)。
# 第三步,更改XY_枚举值前缀(全局匹配)。
# 第四步,更改XYY_文件名前缀。
# 第五步,更改XYM_文件名前缀(可选)。

# 需要修改的‘类名’前缀(需要替换)
pre_str = ''
# 新的‘类名’前缀(需要替换)
pre_to_str = ''

# 需要修改的文件中‘字符串’前缀(需要替换)
pre_var_str = 'XY_'
# 新的文件中‘字符串’前缀(需要替换)
pre_to_var_str = 'Ymx_'

# 需要修改的‘图片名’前缀(需要替换)
pre_pic_str = 'XYYI_'
# 新的‘图片名’前缀(需要替换)
pre_to_pic_str = 'Ymxi_'

# 搜寻以下文件类型(自己需要替换) , '.nib'
suf_set = ('.h', '.m', '.xib', '.storyboard', '.mm', '.pch', '.swift')
pic_suf_set = ('.png', '.jpg')

# 工程项目根路径(需要替换)
project_path = '/Users/yanjin/Desktop/YanJin-Workspace/Temp/XYSDK'

# 定义一个字典 key=旧类名 value=新类名
needModifyDic = {}
pbxprojFileAry = []
# 要修改的文件前缀 {pre_str : pre_to_str}
prefixDic = {'XY_':'XYY_'}
# prefixDic = {'XY_':'Ymx_',
#              'XYX_':'Ymx_',
#              'XYY_':'Ymx_',
#              'XYM_':'Ymx_'}

# 文件重命名函数,返回新的文件名
def file_rename(file_path):
    root_path = os.path.split(file_path)[0]     # 文件目录
    root_name = os.path.split(file_path)[1]     # 文件名包含扩展名
    filename = os.path.splitext(root_name)[0]  # 文件名
    filetype = os.path.splitext(root_name)[1]  # 文件扩展名

    new_file_name = filename.replace(pre_str, pre_to_str)
    if filetype in pic_suf_set:
        new_file_name = filename.replace(pre_pic_str, pre_to_pic_str)

    new_path = os.path.join(root_path, new_file_name + filetype)  # 拼接新路径
    os.renames(file_path, new_path)             # 文件重命名
    print('⚠️ %s --To--> %s' % (filename, new_file_name))
    return new_file_name

def rename_file(root, file_name):
    # 指定前、后缀,匹配具体范围的文件
    file_suf_set = suf_set + ('.nib', '.plist',)
    if (file_name.startswith((pre_str,)) and file_name.endswith(file_suf_set)) or \
            (file_name.startswith((pre_pic_str,)) and file_name.endswith(pic_suf_set)):
        print('file_name: %s' % file_name)
        old_name = os.path.splitext(file_name)[0]
        new_name = file_rename(os.path.join(root, file_name))
        needModifyDic[old_name] = new_name

# 修改项目中文件的前缀
def modify_file_prefix(project_path):
    for (root, dirs, files) in os.walk(project_path):
        # print('root : %s ' % root)
        # 修改nib文件(有些nib是个文件夹)
        for dir_name in dirs:
            filetype = os.path.splitext(dir_name)[1]
            if filetype == '.xcodeproj':
                # 项目配置文件路径(需要替换)(显示包内容 app.xcodeproj,找到project.pbxproj)
                # 项目配置文件路径拼接,为了更新重命名后 配置文件中的 ‘旧文件名’ 为 ‘新文件名’
                pbxproj = root + '/' + dir_name + '/project.pbxproj'
                pbxprojFileAry.append(pbxproj)
                print('xcodeproj_name: %s -> %s' % (dir_name, pbxproj))
            elif filetype in ('.xib', '.nib'):
                # 可视化文件重命名,修改nib文件(有些nib是个文件夹)
                rename_file(root, dir_name)

        # 修改普通文件
        for file_name in files:
            rename_file(root, file_name)

# 更新替换project.pbxproj配置文件中的类名
def modify_pbxproj_file(pbxproj_file):
    for key in needModifyDic:
        with open(pbxproj_file, 'r+') as f:
            s0 = f.read()
            f.close()
            if key in s0:
                with open(pbxproj_file, 'r+') as f2:
                    s = f2.read().replace(key, needModifyDic[key])
                    f2.seek(0)
                    f2.write(s)
                    f2.truncate()
                    f2.close()

# 遍历文件,在文件中更换 "新类名" 的引用
def update_file_name(file_name, root):
    if file_name.endswith(suf_set):
        # print('-----fileName : %s-------' % file_name)
        with open(os.path.join(root, file_name), 'r+') as f:
            s0 = f.read()
            f.close()
            for key in needModifyDic:
                if key in s0:
                    with open(os.path.join(root, file_name), 'r+') as f4:
                        s1 = f4.read().replace(key, needModifyDic[key])
                        print('update ' + key + ' --To--> ' + needModifyDic[key])
                        f4.seek(0)
                        f4.write(s1)
                        f4.truncate()
                        f4.close()

# 对文件中,符合规则的 “常量” 进行前缀的重命名(匹配替换)
def rename_var_prefix(file_name, root):
    if file_name.endswith(suf_set):
        with open(os.path.join(root, file_name), 'r+') as f4:
            s1 = f4.read()
            # \b 匹配单词的边界, 若 pre_str = 'XY_',则 TXY_、xy_格式的不会被匹配到
            s1 = re.sub(r'\b%s' % pre_var_str, pre_to_var_str, s1)
            f4.seek(0)
            f4.write(s1)
            f4.truncate()
            f4.close()

def main():
    print('-------- 💡 1、修改文件名(前缀)---------')
    modify_file_prefix(project_path)

    print('-------- 💡 2、修改配置文件---------')
    print(pbxprojFileAry)
    for file in pbxprojFileAry:
        print('修改配置文件: %s ' % file)
        modify_pbxproj_file(file)

    print('-------- 💡 3、文件重命名后,更换新类名的引用 ---------')
    print('符合重命名规则的文件如下:')
    print(needModifyDic)
    # 遍历文件,在文件中更换 "新类名" 的引用
    if len(needModifyDic) > 0:
        for (root, dirs, files) in os.walk(project_path):
            for file_name in files:
                update_file_name(file_name, root)

    print('-------- 💡 4、遍历所有文件,对文件中符合规则的 “字符串” 进行前缀的重命名(匹配替换) ---------')
    # 遍历文件,对符合规则的 “常量” 进行前缀的重命名(匹配替换)
    for (root, dirs, files) in os.walk(project_path):
        for file_name in files:
            rename_var_prefix(file_name, root)

    print('-------- 🏅 5、 Successful 🏅 --------')

# Press the green button in the gutter to run the script.
if __name__ == '__main__':
    # \b 匹配单词的边界 匹配替换结果:'TXY_TT HJQJ_TT xx xy HJQJ_ xy_'
    # str = re.sub(r'\b%s' % pre_str, pre_to_str, 'TXY_TT XY_TT xx xy XY_ xy_')

    # 更新路径参数为可选,若添加了会覆盖脚本文件中的project_path
    if len(sys.argv) > 1:
        project_path = sys.argv[1]

    if not os.path.exists(project_path):
        print('》》请确认项目路径《《')

    for key, value in prefixDic.items():
        pre_str = key
        pre_to_str = value
        # 重命名文件前缀
        if len(pre_str) > 0 and len(pre_to_str) > 0:
            main() 

⚠️ 注意

若项目中存在引入的bundle文件,需要重新引入替换,否则可能会出现xib加载失败的问题!(具体原因暂未查明)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,290评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,399评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,021评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,034评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,412评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,651评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,902评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,605评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,339评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,586评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,076评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,400评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,060评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,851评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,685评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,595评论 2 270

推荐阅读更多精彩内容