Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 369
  • Last Modified:

MS Dos Command to Copy

Hi Experts,

I'm trying to using ms dos to copy files between two given dates, is there a specific command for that? I already tried using /D with xcopy but it copies files changed on or after the specified date. Any help will be greatly appreciated.

Thanks
0
Samoin
Asked:
Samoin
  • 3
  • 2
1 Solution
 
moonie42Commented:
Use robocopy as it supports a minage and maxage flag:
robocopy c:\source c:\destination *.* /MAXAGE:20101231 /MINAGE:20111001
0
 
Bill PrewCommented:
Agreed there is no baseline DOS command to do the date range copy you seek.  ROBOCOPY is a good alternative, which is a free addon utility Microsoft create a while back and made available through windows resource kits.  It is now included as part of Windows 7 also.  But depending on your Windows version you may have to download and install it.

Since you will need to run something other than just DOS commands to do this, another approach would be a rather small vbscript that could do the date range checking and copy the matching files easily.  Let me know if you are interested in seeing a sample of that approach.

~bp
0
Microsoft Certification Exam 74-409

Veeam® is happy to provide the Microsoft community with a study guide prepared by MVP and MCT, Orin Thomas. This guide will take you through each of the exam objectives, helping you to prepare for and pass the examination.

 
SamoinAuthor Commented:
@billprew

Can you please forward me the sample script.

Thanks
0
 
Bill PrewCommented:
Here's the basic idea, see if this makes sense.  You would run it with a command line from BAT as follows:

cscript //nologo EE27345823.vbs c:\from c:\to 9/1/2011 9/29/2011

' Define file system object, get from folder handle
Set objFSO = CreateObject("Scripting.FileSystemObject")

' Make sure all 4 parms provided
If Wscript.Arguments.Count < 4 Then
   Wscript.Echo "Usage: cscript yourfile.vbs <from folder> <to folder> <from date> <to date>"
   Wscript.Quit
End If

' Get from and to folders from command line
strFromDir = Wscript.Arguments(0)
strToDir = Wscript.Arguments(1)

' Make sure directory names end in backslash
If Right(strFromDir, 1) <> "\" Then strFromDir = strFromDir & "\"
If Right(strToDir, 1) <> "\" Then strToDir = strToDir & "\"

' Make sure they both already exist
If Not objFSO.FolderExists(strFromDir) Then
   Wscript.Echo "Usage: cscript yourfile.vbs <from folder> <to folder> <from date> <to date>"
   Wscript.Quit
End if
If Not objFSO.FolderExists(strToDir) Then
   Wscript.Echo "Usage: cscript yourfile.vbs <from folder> <to folder> <from date> <to date>"
   Wscript.Quit
End if

' Get date range to process files from
datFromDate = CDate(Wscript.Arguments(2))
datToDate = CDate(Wscript.Arguments(3))

' Make sure the dates were entered in proper order
If datFromDate > datToDate Then 
   datFromDate = CDate(Wscript.Arguments(3))
   datToDate = CDate(Wscript.Arguments(2))
End If

' Process all files in the from folder, check if they are in the date range, copy if so
Set objFromDir = objFSO.GetFolder(strFromDir)
For Each objFile In objFromDir.Files
   if objFile.DateLastModified >= datFromDate And objFile.DateLastModified <= datToDate Then
      Wscript.Echo "Copying [" & objFile.Path & "] to [" & strToDir & objFile.Name & "]"
      objFile.Copy strToDir & objFile.Name
   End If
Next

Open in new window

~bp
0
 
Bill PrewCommented:
Thanks much, glad that helped.

~bp
0

Featured Post

What is SQL Server and how does it work?

The purpose of this paper is to provide you background on SQL Server. It’s your self-study guide for learning fundamentals. It includes both the history of SQL and its technical basics. Concepts and definitions will form the solid foundation of your future DBA expertise.

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now