教你如何利用bat脚本批量 重命名/复制 文件

2022-12-30 145阅读 0评论

?=在平时运维的时候,最繁琐的就是要每个月写运维记录的文档如Excel表格,一个月30日要产生30个文件,拷30个运维记录文档的模版再进行重命名实在太麻烦了,所以想到Copy模版之后可以用脚本来对文件进行重命名自己想要的效果,首先给出效果图

教你如何利用bat脚本批量 重命名/复制 文件

教你如何利用bat脚本批量 重命名/复制 文件

下面给出脚本

@echo off set /p m=请输入月份如:5(m): set a=0 setlocal EnableDelayedExpansiON DIr /b .\*.xls | find /c /v "" >> .\tmp.txt set /p c=<.\tmp.txt del /a /f /q .\tmp.txt   for %%i in (*.xls) do ( set /a a+=1 if !a! gtr %c% (Goto aa) echo !a! echo %%i  ren "%%i" "日常运维检查记录2018-%m%-!a!.xls" ) :aa pause

脚本解释:

dir /b下面接上find命令统计当前目录下的xls格式的文件数,这里假设我运维记录的文件使xls格式的,然后把统计的文件数写入txt文件中,例如有5个xls文件就会把5写入,然后从这个txt中读出这个数字赋值给c变量,再把这个txt文件删除

后面的for循环就是重命名文件了,这里注意有一点,为什么我在for循环中要加个条件语句呢?这个条件语句的意思是一旦a变量(这里a代表着文件重命名中的文件名天数的后缀名,由1开始计数,直到达到文件夹中重命名的xls文件数为止)大于c变量(统计的用于重命名xls文件数),就会终止这个循环并且跳出到aa,这里发现在重命名文件的时候会循环会溢出多一次,也就是假设原来有5个xls文件要重命名,在用这个循环重命名的时候如果不加这个if语句来防止溢出,就会重命名了6次,从而把第一个重命名的文件再次重命名,这里给出图给大家看一下就知道了

这里加入有5个3月份的运维检查记录文件

教你如何利用bat脚本批量 重命名/复制 文件

假如我在代码中把if语句屏蔽

教你如何利用bat脚本批量 重命名/复制 文件

然后执行脚本,把这5个文件重命名成4月份的运维检查记录文件

教你如何利用bat脚本批量 重命名/复制 文件

发现循环执行了6次,并且看到最后一次重命名把第一个重命名的文件4-1给替换调了4-6

教你如何利用bat脚本批量 重命名/复制 文件

经过上面的解释,大家应该有个理解了把!

在代码中我这里规定了重命名的文件后缀的年份是2018年,这里大家可以模仿月份的输入set /p来加上一个年份的输入,引用变量就可以重命名自己想要的年份后缀名,下面说下这个重命名脚本的使用规则,注意将脚本文件先保存成ansi编码的格式再在里面编辑含有中文的代码,不然重命名或者执行脚本的时候会报错

重命名文件.bat1新建月份文件夹如:4月2关闭360等软件3复制运维记录的文件到月份文件夹下4把脚本放在月份文件夹下执行

就可以看到当前文件夹下会有我们重命名的文件名字了

其实与其重命名文件,大家也可以考虑用复制文件办法,这样就不用考虑重命名时候的溢出问题,下面给出文件复制的办法

@echo off set /p year=请输入年份如:2018(year): set /p month=请输入月份如:4(month): set /p day=请输入这个月的天数如:30(day): if %day%==31 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls GOto aa) if %day%==30 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls  goto aa) if %day%==29 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls goto aa) if %day%==28 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls  goto aa) if %day%==27 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls  goto aa) if %day%==26 ( for /l %%d in (1,1,%day%) do copy .\module.xls .\日常运维检查记录%year%-%month%-%%d.xls  goto aa)  echo "输入的天数不符合规则!"  :aa pause exit 

代码比较简单,这里我规定了要把module.xls这个运维记录的模版文件放在当前新建的月份文件夹下,然后通过复制这个文件来生成对应天数的运维检查记录文件,这里我规定了天数26-31天,同样要注意的是脚本的编码要是ansi编码

下面给出操作方法和效果图

批量复制文件.BAT1新建月份文件夹如:4月2将模版文件更名为module.xls放在月份文件夹下

3把脚本放在月份文件夹下面执行脚本输入参数

教你如何利用bat脚本批量 重命名/复制 文件

教你如何利用bat脚本批量 重命名/复制 文件

到此这篇关于教你如何利用bat脚本批量 重命名/复制 文件的文章就介绍到这了,更多相关bat脚本批量 重命名内容请搜索云初冀北以前的文章或继续浏览下面的相关文章希望大家以后多多支持云初冀北!

免责声明
本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:goliszhou@gmail.com
$

发表评论

表情:
评论列表 (暂无评论,145人围观)

还没有评论,来说两句吧...