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

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

教你如何利用bat脚本批量 重命名/复制 文件_第1张图片

教你如何利用bat脚本批量 重命名/复制 文件_第2张图片

下面给出脚本

@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脚本批量 重命名/复制 文件_第3张图片

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

教你如何利用bat脚本批量 重命名/复制 文件_第4张图片

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

教你如何利用bat脚本批量 重命名/复制 文件_第5张图片

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

教你如何利用bat脚本批量 重命名/复制 文件_第6张图片

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

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

重命名文件.bat
1新建月份文件夹如: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编码

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

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

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

教你如何利用bat脚本批量 重命名/复制 文件_第7张图片

教你如何利用bat脚本批量 重命名/复制 文件_第8张图片

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

你可能感兴趣的:(教你如何利用bat脚本批量 重命名/复制 文件)