CN111198712A - 一种项目文件名批量自动替换方法 - Google Patents

一种项目文件名批量自动替换方法 Download PDF

Info

Publication number
CN111198712A
CN111198712A CN201911313733.XA CN201911313733A CN111198712A CN 111198712 A CN111198712 A CN 111198712A CN 201911313733 A CN201911313733 A CN 201911313733A CN 111198712 A CN111198712 A CN 111198712A
Authority
CN
China
Prior art keywords
file
replacement
code
content
replaced
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201911313733.XA
Other languages
English (en)
Inventor
田云翔
唐进
郑鸿洋
段凌云
陈正超
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Guiyang Yuwan Technology Co ltd
Original Assignee
Guiyang Yuwan Technology Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Guiyang Yuwan Technology Co ltd filed Critical Guiyang Yuwan Technology Co ltd
Priority to CN201911313733.XA priority Critical patent/CN111198712A/zh
Publication of CN111198712A publication Critical patent/CN111198712A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/73Program documentation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/16File or folder operations, e.g. details of user interfaces specifically adapted to file systems
    • G06F16/164File meta data generation
    • G06F16/166File name conversion

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Human Computer Interaction (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Library & Information Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了一种项目文件名批量自动替换方法,首先在白名单中添加筛选条件,根据该筛选条件遍历获取工程目录下所有的文件,过滤出需要替换的文件;然后获取所有代码文件名以及可能需要修改的文件内容,在可能需要修改的文件内容中进行正则匹配,匹配成功对其进行修改替换;最后把替换后的内容写入原来的文件。使用本发明能在10分钟内完成3000个文件,50万行代码的整理替换工作;解决了人工替换时间长,容易出错的问题。

Description

一种项目文件名批量自动替换方法
技术领域
本发明涉及项目管理技术领域,尤其涉及的是一种项目文件名批量自动替换方法。
背景技术
在软件项目开发的过程中,因为开发人员个人习惯的问题,代码命名不一定统一,在代码整理存档或者迁移到新项目时,就需要进行一个统一的命名整理工作。替换一个文件名就需要修改若干处关联的代码,不仅费时费力,而且容易出错。在大型项目中替换的工作量将成指数级的增长。在旧的项目整理、代码迁移的过程中,经常需要进行文件名整理替换的工作,人工替换将花费大量的时间与精力,而且容易出现错误的情况。
因此,现有技术存在缺陷,需要改进。
发明内容
本发明所要解决的技术问题是针对现有技术的不足提供一种项目文件名批量自动替换方法。
本发明的技术方案如下:
一种项目文件名批量自动替换方法,首先在白名单中添加筛选条件,根据该筛选条件遍历获取工程目录下所有的文件,过滤出需要替换的文件;然后获取所有代码文件名以及可能需要修改的文件内容,在可能需要修改的文件内容中进行正则匹配,匹配成功对其进行修改替换;最后把替换后的内容写入原来的文件。
所述的项目文件名批量自动替换方法,包括以下具体步骤:
步骤1:过滤筛选步骤:设置过滤筛选条件白名单,通过在白名单中添加文件名、文件类型或者文件夹路径等筛选条件,过滤出需要替换的文件;
步骤2:智能去重步骤:过滤后的代码文件,先读入代码文件中的内容,如果代码文件引用了文件名,则只加载代码文件;如果代码文件使用了该文件名对应文件的内容中的代码,则需要加载代码文件及其头文件,若代码文件未使用该文件名对应文件的内容中的代码且未引用该文件名则不需要加载任何的内容,只把可能需要修改的内容读入内存;
步骤3:读取用户希望的替换规则;
步骤4:系统会遍历内存中的文件内容,通过正则表达式的方式来寻找需要替换的文件名;如果通过正则表达式未匹配上,会智能切换完全搜索模式,通过遍历所有文件内容,进行字符串搜索,来确保不会出现遗漏。
步骤5:在内存中对搜索到的结果进行替换,当所有替换完成后再写回原文件。
所述的项目文件名批量自动替换方法,筛选条件包括文件名、文件类型或者文件夹路径。
所述的项目文件名批量自动替换方法,替换规则为:原名精确替换,前缀批量添加,前缀批量替换,前缀批量过滤,还支持简单替换,只需输入当前有的前缀,会智能判断是需要添加还是替换新的前缀。
所述的项目文件名批量自动替换方法,正则表达式的匹配规则为:以原始的文件名作为关键词,在所有文件内容中匹配关键词两端存在单词边界的情况;单词边界是单词和符号之间的边界,匹配得到单词边界后继续匹配前后是否出现加号。有单词边界,且未出现加号的就是匹配成功,表示需要进行替换。
所述的项目文件名批量自动替换方法,单词可以是中文字符、英文字符及数字;符号可以是中文符号、英文符号、空格、制表符及换行。
使用本发明能在10分钟内完成3000个文件,50万行代码的整理替换工作。解决了人工替换时间长,容易出错的问题。
具体实施方式
以下结合具体实施例,对本发明进行详细说明。
本发明提供了文件白名单指定规则替换功能,可以简便的替换为目标格式。首先通过在白名单中添加文件名、文件类型或者文件夹路径等筛选条件,根据该筛选条件遍历获取工程目录下所有的文件,过滤出需要替换的文件。
然后获取所有代码文件名以及可能需要修改的文件内容,在可能需要修改的文件内容中进行正则匹配,匹配成功对其进行修改替换。
最后把替换后的内容写入原来的文件。这里可以根据用户自定义规则进行替换,也可以使用默认规则进行替换。
包括以下具体步骤:
步骤1:过滤筛选步骤:设置过滤筛选条件白名单,通过在白名单中添加文件名、文件类型或者文件夹路径等筛选条件,过滤出需要替换的文件,支持通过“路径”、“文件名”、“文件类型”3种方式来对目标代码文件进行过滤筛选,经过这次过滤可以大大的加快处理速度。
步骤2:智能去重步骤:过滤后的代码文件,先读入代码文件中的内容,如果代码文件引用了文件名,则只加载代码文件。如果代码文件使用了该文件名对应文件的内容中的代码,则需要加载代码文件及其头文件,若代码文件未使用该文件名对应文件的内容中的代码且未引用该文件名则不需要加载任何的内容,只把可能需要修改的内容读入内存。
例如,在iOS软件开发中,一个类由头文件“类名.h”和源文件“类名.m”两个文件组成。步骤1过滤筛选出来的文件进行排重操作,得到一组不重复的类名。在工程所有文件中搜索这些类名,对于每一个文件,需进行以下2个条件判断:条件1、这些类名是否在文件中有引用(即头文件被使用)。条件2、文件中是否通过这些类名创建了实例对象或者调用了方法(即源文件被使用)。只要满足了条件2,就需要同时加载该文件对应类的头文件和源文件。如果仅满足了条件1,则只需要加载该文件对应类的头文件即可。若都不满足则不需要加载。通过分析只把可能需要修改的内容读入内存,加快了程序的处理速度。(类是面向对象程序设计实现信息封装的基础。类是一种用户定义的引用数据类型,也称类类型。每个类包含数据说明和一组操作数据或传递消息的函数。类的实例称为对象。)
步骤3:读取用户希望的替换规则,例如替换规则为:原名精确替换,前缀批量添加,前缀批量替换,前缀批量过滤,还支持简单替换,只需输入当前有的前缀,会智能判断是需要添加还是替换新的前缀。
步骤4:系统会遍历内存中的文件内容通过正则表达式的方式来寻找需要替换的文件名。
正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串、将匹配的子串替换或者从某个串中取出符合某个条件的子串等。通过对iOS中常见文件、常用命名进行分析,同时进行了大量的实验,最终得出本发明的关键匹配规则,通过正则表达式的单词边界加条件过滤来匹配目标文件名。
具体的匹配规则如下:以原始的文件名作为关键词,在所有文件内容中匹配关键词两端存在单词边界的情况;单词边界是单词和符号之间的边界,单词可以是中文字符、英文字符及数字。符号可以是中文符号、英文符号、空格、制表符及换行,匹配得到单词边界后继续匹配前后是否出现加号。有单词边界,且未出现加号的就是匹配成功,表示需要进行替换。
通过此规则,能准确快速的匹配到需要替换的内容。
另外也提供了完全搜索模式,如果通过正则未匹配上,会智能切换完全搜索模式,通过遍历所有文件内容,进行字符串搜索,来确保不会出现遗漏。
步骤5:在内存中对搜索到的结果进行替换,当所有替换完成后再写回原文件。这样做可以避免文件的频繁读取,大大的提高了程序的运行速度。
使用本发明能在10分钟内完成3000个文件,50万行代码的整理替换工作。解决了人工替换时间长,容易出错的问题。
例如,在lemo app的iOS客户端代码整理的过程中,我们需要替换工程“Modules”目录及其子目录下的所有文件名,这些文件有些是以“YW”开头的也有直接以内容命名的。我们需要把“YW”开头的文件名替换为“VST”开头,对于直接以内容命名的,我们需要在前面补上“VST”。同时还需要对工程中所有代码文件里引用到这个文件的地方进行替换。通过本发明,我们只需要简单设置一下,就能快速、准确的完成这个任务。
首先我们设置好需要替换的工程文件的路径“/VostucIOS/Modules”。然后在白名单中添加上需要参与替换的文件类型的后缀名集合“[c,m,h,mm,pch]”,c,m,h,mm,pch均代表一种后缀名,通过文件后缀来筛选,多种类型后缀名之间用逗号隔开。
最后设置上需要替换的规则,例如这里我们设置上“YW”替换成“VST”,点击执行就可以了。等待处理完成后,指定路径中所有的文件名全部添加或替换成“VST”开头的文件名,另外,在整个工程代码中,如果对该路径下文件有引用的地方,也全部自动进行了匹配修改。通过本发明,大大的降低了时间成本,增加了替换的准确性,更好、更快的完成了任务。
应当理解的是,对本领域普通技术人员来说,可以根据上述说明加以改进或变换,而所有这些改进和变换都应属于本发明所附权利要求的保护范围。

Claims (6)

1.一种项目文件名批量自动替换方法,其特征在于,首先在白名单中添加筛选条件,根据该筛选条件遍历获取工程目录下所有的文件,过滤出需要替换的文件;然后获取所有代码文件名以及可能需要修改的文件内容,在可能需要修改的文件内容中进行正则匹配,匹配成功对其进行修改替换;最后把替换后的内容写入原来的文件。
2.根据权利要求1所述的项目文件名批量自动替换方法,其特征在于,包括以下具体步骤:
步骤1:过滤筛选步骤:设置过滤筛选条件白名单,通过在白名单中添加筛选条件,过滤出需要替换的文件;
步骤2:智能去重步骤:过滤后的代码文件,先读入代码文件中的内容,如果代码文件引用了文件名,则只加载代码文件;如果代码文件使用了该文件名对应文件的内容中的代码,则需要加载代码文件及其头文件,若代码文件未使用该文件名对应文件的内容中的代码且未引用该文件名则不需要加载任何的内容,只把可能需要修改的内容读入内存;
步骤3:读取用户希望的替换规则;
步骤4:系统会遍历内存中的文件内容,通过正则表达式的方式来寻找需要替换的文件名;如果通过正则表达式未匹配上,会智能切换完全搜索模式,通过遍历所有文件内容,进行字符串搜索,来确保不会出现遗漏。
步骤5:在内存中对搜索到的结果进行替换,当所有替换完成后再写回原文件。
3.根据权利要求2所述的项目文件名批量自动替换方法,其特征在于,筛选条件包括文件名、文件类型或者文件夹路径。
4.根据权利要求2所述的项目文件名批量自动替换方法,其特征在于,替换规则为:原名精确替换,前缀批量添加,前缀批量替换,前缀批量过滤,还支持简单替换,只需输入当前有的前缀,会智能判断是需要添加还是替换新的前缀。
5.根据权利要求2所述的项目文件名批量自动替换方法,其特征在于,正则表达式的匹配规则为:以原始的文件名作为关键词,在所有文件内容中匹配关键词两端存在单词边界的情况;单词边界是单词和符号之间的边界,匹配得到单词边界后继续匹配前后是否出现加号;有单词边界,且未出现加号的就是匹配成功,表示需要进行替换。
6.根据权利要求5所述的项目文件名批量自动替换方法,其特征在于,单词可以是中文字符、英文字符及数字;符号可以是中文符号、英文符号、空格、制表符及换行。
CN201911313733.XA 2019-12-19 2019-12-19 一种项目文件名批量自动替换方法 Pending CN111198712A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911313733.XA CN111198712A (zh) 2019-12-19 2019-12-19 一种项目文件名批量自动替换方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911313733.XA CN111198712A (zh) 2019-12-19 2019-12-19 一种项目文件名批量自动替换方法

Publications (1)

Publication Number Publication Date
CN111198712A true CN111198712A (zh) 2020-05-26

Family

ID=70744419

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911313733.XA Pending CN111198712A (zh) 2019-12-19 2019-12-19 一种项目文件名批量自动替换方法

Country Status (1)

Country Link
CN (1) CN111198712A (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111813747A (zh) * 2020-07-09 2020-10-23 广东一一五科技股份有限公司 文件批量重命名方法、电子设备及计算机可读存储介质
CN112329018A (zh) * 2020-10-31 2021-02-05 方正株式(武汉)科技开发有限公司 一种struts替换方法
CN112835857A (zh) * 2021-02-07 2021-05-25 福建师范大学 一种工作群组的文件主名管理方法
CN114201178A (zh) * 2022-02-17 2022-03-18 武大吉奥信息技术有限公司 一种批量解决sdk资源冲突的方法

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111813747A (zh) * 2020-07-09 2020-10-23 广东一一五科技股份有限公司 文件批量重命名方法、电子设备及计算机可读存储介质
CN112329018A (zh) * 2020-10-31 2021-02-05 方正株式(武汉)科技开发有限公司 一种struts替换方法
CN112835857A (zh) * 2021-02-07 2021-05-25 福建师范大学 一种工作群组的文件主名管理方法
CN114201178A (zh) * 2022-02-17 2022-03-18 武大吉奥信息技术有限公司 一种批量解决sdk资源冲突的方法

Similar Documents

Publication Publication Date Title
CN111198712A (zh) 一种项目文件名批量自动替换方法
US7424646B2 (en) Imposing a logical structure on an unstructured trace record for trace analysis
CN111259627A (zh) 文档分析方法、装置、计算机存储介质及设备
CN112364024A (zh) 一种表数据批量自动比对的控制方法及装置
CN113094442B (zh) 全量数据同步方法、装置、设备和介质
CN116150093B (zh) 一种对象存储列举对象的实现方法及电子设备
CN109542942B (zh) 函数调用的查询方法及装置、电子设备
CN111475464A (zh) 一种自动发现挖掘Web组件指纹的方法
CA2453971C (en) On-demand creation of java locale source
US10936563B2 (en) System and method for merging a source data from a source application into a target data of a target application
CN110795915A (zh) xml文件批量修改方法、系统、设备和计算机可读存储介质
CN104991963B (zh) 文件处理方法和装置
CN112115159B (zh) 一种sql语句的生成方法、装置、电子设备和存储介质
CN111045991B (zh) 一种基于命令行模式快速打开文件的实现方法
CN113342749A (zh) 文件路径匹配方法、装置、设备及计算机可读存储介质
CN113792026A (zh) 数据库脚本的部署方法、装置及计算机可读存储介质
Magnusson THÈME User’s manual
CN111124548B (zh) 一种基于yaml文件的规则解析方法及系统
CN109726284B (zh) 一种通用性强的数据分析方法
Jemison Enhancing Print Journal Analysis for Shared Print Collections
CN112148710B (zh) 微服务分库方法、系统和介质
CN110740058B (zh) 用于制作网络割接脚本的设备数据提取方法及装置
CN1271905A (zh) 在比较语句序列中采用判别比较的方法和设备
CN117909974A (zh) 基于自动化yara规则实现大规模恶意样本识别及归因处理的方法、装置、处理器及介质
CN117193838A (zh) 小程序样式文件的优化方法及装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination