Solved

Creating folders and sub folder in a batch file

Posted on 2008-10-24
6
731 Views
Last Modified: 2012-06-21
Hi,

Is there a way of creating a range of folders and within the range of folders are 3 sub-folders in a batch file?
For instance i want to create a set of folders from 100 to 150 and within each of these folders are the exact same sub-folders called Reports, Misc and Spreadsheets.

I kind of figured out how to create a single folder and with the 3 sub folder but not too create a whole range without having to input the number manually.
So so far i have a createfol.bat file with the follwoing commands:
mkdir %1\reports
mkdir %1\spreadsheets
mkdir %1\misc

I can run this .bat in the cmd by typing
createfol.bat 100
Now this creates the folder 100 with the subfolders i want but i dont want to have to do this another 200-300 times to create the others.

Is there an easier way? any help really appreciated

Thanks for you help in advance
0
Comment
Question by:Lau888
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
6 Comments
 
LVL 2

Expert Comment

by:jonathonberg
ID: 22794883
Create another batch file using creatfol.bat 100, use excel to create the command for each folder (100-159) and paste the commands into the new batch file and run.
0
 

Author Comment

by:Lau888
ID: 22794937
Hi,
Thanks for the quick reply.

Apologies if i am being stupid, but i am not quite sure what it is you mean? The createfol.bat i have includes the commands to create the sub-folders only. So in order for me to create the root folder i.e 100 i have to go into command prompt and type in "createfol.bat 100" so now if i wish to create a folder called 101 with the same sub-folders i have to type teh following in comman prompt again "createfol.bat 101"

So what would i need put into excel in order to create the new batch file? Sorry about this bit of a begineer when it comes to scripting.

Thanks
0
 
LVL 84

Expert Comment

by:oBdA
ID: 22795116
Try the script below. It uses a loop ("for /L"), and the script now requires two command line arguments: the first folder number to be created and the last one.
createfol 100 150
It's currently in test mode, so that you can try it; it will only display the "md" commands it would otherwise run.
Remove the capitalized ECHOs in front of the md commands to run it for real.
@echo off
setlocal
if "%~2"=="" (
  echo Syntax: %~nx0 ^<starting number^> ^<end number^>
  goto :eof
)
set RangeStart=%~1
set RangeEnd=%~2
for /l %%i in (%RangeStart%, 1, %RangeEnd%) do (
  echo Processing folder %%i ...
  ECHO md "%%i\reports"
  ECHO md "%%i\spreadsheets"
  ECHO md "%%i\misc"
)

Open in new window

0
Why You Need a DevOps Toolchain

IT needs to deliver services with more agility and velocity. IT must roll out application features and innovations faster to keep up with customer demands, which is where a DevOps toolchain steps in. View the infographic to see why you need a DevOps toolchain.

 

Author Comment

by:Lau888
ID: 22796096
Sorry odba, you will have to excuse my poor knowledge of all this. I have tried to use your script and removed ECHO but it doesnt seem to work. Also changed the where it says "RangeStart" and " RangeEnd" to the number i require and it still doesnt work. Am i doing something incorrect???

Apologies again if it is a simple mistake.

Thanks
0
 
LVL 84

Accepted Solution

by:
oBdA earned 250 total points
ID: 22796267
Copy and paste the script above as it is, and save it as "CreateFolders.cmd".
Open a command prompt in the folder you've saved the script in, and enter
CreateFolders 100 150
The result should look something like this:

C:\Temp>CreateFolders 100 150
Processing folder 100 ...
md "100\reports"
md "100\spreadsheets"
md "100\misc"
Processing folder 101 ...
md "101\reports"
md "101\spreadsheets"
md "101\misc"
Processing folder 102 ...
etc.

The <md "101\reports"> lines are the commands that the script would run if you remove the ECHO commands, so that you can verify it actually generates the folder names you want.
You can add the absolute target path to the "md" commands as well, that will make the script independent of the folder it's started from, for example like this (with the main folder being "D:\Data\Files"):
  ECHO md "D:\Data\Files\%%i\reports"
%%i goes wherever you want the "numbered" folder appear.
0
 

Author Comment

by:Lau888
ID: 22796394
That worked!!

Many thanks obda, you are a life saver!!!
0

Featured Post

Business Impact of IT Communications

What are the business impacts of how well businesses communicate during an IT incident? Targeting, speed, and transparency all matter. Find out more in this infographic.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

If like me you are one who spends a lot of time working and scripting with cmd.exe, sometimes it is handy to be able to quickly view a calendar for a given month and year. This script will quickly do just that!  Save the code posted below to a .bat …
You may have already been in the need to update a whole folder stucture using a script. Robocopy does it well and even provides a list of non-updated files in a log (if asked to). Generally those files that were locked by a user or a process by the …
Learn the basics of while and for loops in Python.  while loops are used for testing while, or until, a condition is met: The structure of a while loop is as follows:     while <condition>:         do something         repeate: The break statement m…
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)

739 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question