我有一个多个州的合同文件夹,每个州的文件夹都有多个合同:
D:\Workspace\Contracts\State1\Contract1_number_date
D:\Workspace\Contracts\State1\Contract2_number_date
D:\Workspace\Contracts\State2\Contract1_number_date`
etc...
我需要为每份合约制作3个文件夹:
D:\Workspace\Contracts\State1\Contract1_number_date\folder1
D:\Workspace\Contracts\State1\Contract1_number_date\folder2
D:\Workspace\Contracts\State1\Contract1_number_date\folder3
D:\Workspace\Contracts\State1\Contract2_number_date\folder1
D:\Workspace\Contracts\State1\Contract2_number_date\folder2
D:\Workspace\Contracts\State1\Contract2_number_date\folder3
D:\Workspace\Contracts\State2\Contract1_number_date\folder1
D:\Workspace\Contracts\State2\Contract1_number_date\folder2
D:\Workspace\Contracts\State2\Contract1_number_date\folder3
我发现\..\
提升了一级,因此mkdir D:\Workspace\Contracts\..\folder1
生成D:\Workspace\folder1
,但我不知道如何删除1或10个文件夹。
答案 0 :(得分:0)
这里有一些代码使用For
循环来实现您的目标:
@Echo Off
Set "BaseDir=%~1"
Set "NumStates=%~2"
Set "NumContracts=%~3"
Set "NumFolders=%~4"
If Not Exist "%BaseDir%\" Exit/B
For %%A In (NumStates NumContracts NumFolders) Do If Not Defined %%A Exit/B
If /I Not "%CD%"=="%BaseDir%" CD /D "%BaseDir%"
For /L %%A In (1,1,%NumStates%) Do For /L %%B In (1,1,%NumContracts%
) Do For /L %%C In (1,1,%NumFolders%
) Do If Not Exist "State%%A\Contract%%B_number_date\folder%%C\" (
MD "State%%A\Contract%%B_number_date\folder%%C")
您可以从命令行运行名为MakeDirs.cmd
的脚本,如下所示:
"MakeDirs.cmd" "D:\Workspace\Contracts" 17 8 3
以上内容应为3
内的8
合同和17
州创建D:\Workspace\Contracts
个目录。