我在一个目录中有许多SQL脚本,前缀是一个数字,例如
目前,我可以使用此脚本循环遍历它们:
@ECHO OFF FOR /r . %%F IN (*.sql) DO ( ECHO File:"%%F" )
但是,由于Windows读取目录中文件的方式,在2之前读取10和11,等等:
如何按照前缀的顺序遍历目录中的每个文件?
下面的批处理文件在需要它的文件名中插入前导零.
@echo off setlocal EnableDelayedExpansion for /F "delims=" %%f in ('dir /B *.sql') do ( set "filename=%%f" if "!filename:~1,1!" equ "-" ren "%%f" "0%%f" )
编辑:添加了新的解决方案
下面的批处理文件以正确的顺序显示文件而不重命名它们.
@echo off setlocal EnableDelayedExpansion rem Create an array with filenames in right order for %%f in (*.sql) do ( for /F "delims=-" %%n in ("%%f") do ( set "number=00000%%n" set "file[!number:~-6!]=%%f" ) ) rem Process the filenames in right order for /F "tokens=2 delims==" %%f in ('set file[') do ( echo %%f )
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。