[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[日期时间] 批处理如何批量修改日期为前缀的文件名?

各位高手,求助:

文件名规律
201201 文字一.xls
201201 文字二.xls
201201 文字三.xls
批量修改为
201202 文字一.xls
201202 文字一.xls
201202 文字一.xls
如前面为201212,修改为201301
中间以空格隔开,前面是年月组合,后面是长度不定的文字。

谢谢。

高手,学习了

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "tokens=1* delims= " %%a in ('dir /b *.xls') do (
  4.     set stamp=%%a
  5.     set year=!stamp:~0,4!
  6.     set month=1!stamp:~4,2!
  7.     if !month! equ 112 (
  8.         set month=101
  9.         set /a year+=1
  10.     ) else (
  11.         set /a month+=1
  12.     )
  13.     ren "%%a %%b" "!year!!month:~-2! %%b"
  14. )
复制代码

TOP

本帖最后由 apang 于 2012-5-3 17:44 编辑
  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "delims=" %%a in ('dir /a-d /b *.xls') do (
  3.   set "str=%%a"
  4.   set "str1=!str:~,6!"
  5.   if "!str1:~4,2!"=="12" (set/a str1+=89
  6.   ) else set/a str1+=1
  7.   ren "%%a" "!str1!!str:~6!"
  8. )
复制代码

TOP

感谢高手,谢谢

TOP

返回列表