Find Specific Folder in Root of main and all drives attached vbs

岁酱吖の 提交于 2019-12-11 06:54:25

问题


I'd like to look for a specific folder that could be on the root of the main drive of a Windows 7 Machine or on the root of any usb drives attached to it. I'd prefer to do it in vbscript or in an hta (not htaaccess) using vbscript.

ex. I need to find the folder "xyz". It could be either here: C:\xyz or D:\xyz or Z:\xyz etc. I don't care if it's here: c:\Users\Joe\xyz or F:\folder1\xyz.

I figure the search would be fairly quick if the search is concentrated to just the root folders of each drive.


回答1:


This vbscript can looking for folder in all your connected drives, so i add a waiting bar to let the user to be patient until it finish its job

Option Explicit
If AppPrevInstance() Then   
    MsgBox "There is an existing proceeding !" & VbCrLF & CommandLineLike(WScript.ScriptName),VbExclamation,"There is an existing proceeding !"    
    WScript.Quit   
Else 
    Dim ws,fso,LogFile,Title,WaitingMsg,StartTime,DurationTime,FolderName,oExec,Temp
    Set ws = CreateObject("WScript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    LogFile = Left(Wscript.ScriptFullName, InstrRev(Wscript.ScriptFullName, ".")) & "log"
    if fso.FileExists(LogFile) Then
        fso.DeleteFile LogFile
    end if
    FolderName = InputBox("In the box below type in the folder you are looking for","Find Folder by Hackoo 2015","folder")
    If FolderName  = "" Then WScript.Quit
    Temp = ws.ExpandEnvironmentStrings("%Temp%")
    Title = "Looking for folder name "& DblQuote(FolderName) & " using Vbscript by Hackoo 2015"
    WaitingMsg = "Please wait... Searching for folder name : <font color=Yellow>"& DblQuote(FolderName) & "</font> is in progress..."
    Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar
    Call LancerProgressBar() 'Launch of the Waiting Bar
    StartTime = Timer 'Start the Timer Counter
    Call FindFolder(FolderName)
    DurationTime = FormatNumber(Timer - StartTime, 0) & " seconds." 'The duration of the script
    Call FermerProgressBar() 'Closing the Waiting Bar
    ws.Popup "The Searching of " & Dblquote(FolderName) & " is finished in " & DurationTime &" !","5","The Download of " & Dblquote(FolderName) & " is finished in " & DurationTime &" !",64
    ws.run DblQuote(LogFile) ' To open the LogFile
End If
'*************************************************************************************************************************
'Search for Folders
Sub FindFolder(Name)
    Dim strComputer,objWMIService,colFolders,objFolder
    strComputer = "."
    Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")

    Set colFolders = objWMIService.ExecQuery _
    ("Select * from Win32_Directory where Name Like "& CommandLineLike(Name) &"")

    For Each objFolder in colFolders
        WriteLog objFolder.Name
    Next
End sub
'*************************************************************************************************************************
Function CommandLineLike(ProcessPath)   
    ProcessPath = Replace(ProcessPath, "\", "\\")   
    CommandLineLike = "'%" & ProcessPath & "%'"   
End Function
'*************************************************************************************************************************
Function AppPrevInstance()   
    With GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\.\root\cimv2")   
        With .ExecQuery("SELECT * FROM Win32_Process WHERE CommandLine LIKE " & CommandLineLike(WScript.ScriptFullName) & _
            " AND CommandLine LIKE '%WScript%' OR CommandLine LIKE '%cscript%'")   
            AppPrevInstance = (.Count > 1)   
        End With   
    End With   
End Function   
'*****************************************************************************************************************************
Sub WriteLog(strText)
    Dim fs,ts 
    Const ForAppending = 8
    Set fs = CreateObject("Scripting.FileSystemObject")
    Set ts = fs.OpenTextFile(Left(Wscript.ScriptFullName, InstrRev(Wscript.ScriptFullName, ".")) & "log", ForAppending, True)
    ts.WriteLine strText
    ts.Close
End Sub
'*******************************************************************************************************************************
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'*******************************************************************************************************************************
Sub CreateProgressBar(Title,WaitingMsg)
    Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
    Set ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Temp = WS.ExpandEnvironmentStrings("%Temp%")
    PathOutPutHTML = Temp & "\Barre.hta"
    Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
    fhta.WriteLine "<HTML>"
    fhta.WriteLine "<HEAD>"
    fhta.WriteLine "<Title>  " & Title & "</Title>"
    fhta.WriteLine "<HTA:APPLICATION"
    fhta.WriteLine "ICON = ""magnify.exe"" "
    fhta.WriteLine "BORDER=""THIN"" "
    fhta.WriteLine "INNERBORDER=""NO"" "
    fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
    fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
    fhta.WriteLine "SCROLL=""NO"" "
    fhta.WriteLine "SYSMENU=""NO"" "
    fhta.WriteLine "SELECTION=""NO"" "
    fhta.WriteLine "SINGLEINSTANCE=""YES"">"
    fhta.WriteLine "</HEAD>"
    fhta.WriteLine "<BODY text=""white""><CENTER>"
    fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & WaitingMsg &"</font></marquee>"
    fhta.WriteLine "<img src="""" />"
    fhta.WriteLine "</CENTER></BODY></HTML>"
    fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
    fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
    fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
    fhta.WriteLine "Sub window_onload()"
    fhta.WriteLine "    CenterWindow 490,110"
    fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
    fhta.WriteLine " End Sub"
    fhta.WriteLine " Sub CenterWindow(x,y)"
    fhta.WriteLine "    Dim iLeft,itop"
    fhta.WriteLine "    window.resizeTo x,y"
    fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
    fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
    fhta.WriteLine "    window.moveTo ileft,itop"
    fhta.WriteLine "End Sub"
    fhta.WriteLine "</script>"
    fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
    Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
    oExec.Terminate
End Sub
'**********************************************************************************************



回答2:


From Help

Read-only collection of all available drives.

Remarks Removable-media drives need not have media inserted for them to appear in the Drives collection.

The following example illustrates how to get the Drives collection using the Drives property and iterate the collection:

Visual Basic Script Copy Code Function ShowDriveList

   Dim fso, d, dc, s, n

   Set fso = CreateObject("Scripting.FileSystemObject")

   Set dc = fso.Drives

   For Each d in dc

      n = ""

      s = s & d.DriveLetter & " - " 

      If d.DriveType = 3 Then

         n = d.ShareName

      ElseIf d.IsReady Then

         n = d.VolumeName

      Else

         n = "[Drive not ready]"

      End If

      s = s & n & "<BR>"

   Next

   ShowDriveList = s

End Function

Methods The Drives collection has no methods.

Properties Count Property | Item Property

See Also Reference Drive Object Drives Property File Object Files Collection Folder Object Folders Collection




回答3:


Thanks to @user4532213 for leading me in the right direction. Basically the information and code he gave lists all the drives that are attached and ready to use on your computer. It doesn't however look for a particular folder on each drive. So, I took some of what he mentioned and

  1. Created a basic HTA file to make it easy to see if anyone finds this useful.
  2. Added the ability to search for the particular folder on all drives.
  3. Also realized you can use this to search for similar folder paths on different drives.

The usage is remarked in the HTA.

<html>
<Head>
<Title>Folder Finder.HTA</Title>
 
<HTA:Application
APPLICATIONNAME = " Folder Finder.HTA"
Border = Thick
ShowInTaskBar = No
MaximizeButton = Yes
MinimizeButton = Yes>
 
<Script Language = VBScript>
Sub Window_onLoad
	window.resizeTo 400,300
	self.MoveTo 100,100
	searchfoldername.Focus
End Sub

Sub FindFolder
	' this will search all active drives for a folder or path matching the word inputed by user and list them in this HTA.
	' Usage: type in a word to search or a path in the box. 
	' Example: if you type in FOLDERONE it will search C:\FOLDERONE and/or B:\FOLDERONE (as long the drive is ready) etc.
	' Example: if you type in FOLDERONE\SUBFOLDERONE it will search for C:\FOLDERONE\SUBFOLDERONE and/or F:\FOLDERONE\SUBFOLDERONE
   Dim fso, d, dc, s, n, searchfolder
	searchfolder = searchfoldername.value
   Set fso = CreateObject("Scripting.FileSystemObject")

   Set dc = fso.Drives
	i = 0
   For Each d in dc

		s = d.DriveLetter & ":\"
		Set oFSO=CreateObject("Scripting.FileSystemObject")
		If oFSO.FolderExists(s & searchfolder) Then
			s = s & searchfolder & "<BR>"
			ShowDriveList = s & ShowDriveList
			i = i + 1
	    End If


   Next

   document.getElementById("DataArea").innerHTML = i & " matches:" & "<BR>" & ShowDriveList

End Sub
 
</Script><Body>In the box below type in the folder you are looking for<br></br>
<input type="text" name="searchfoldername">&nbsp;</input><br></br>
<input type="button" button value="Search Folder" name="run_button" onClick="FindFolder"><br></br>
<Span Id = "DataArea">&nbsp;</Span></Body>


来源:https://stackoverflow.com/questions/28377931/find-specific-folder-in-root-of-main-and-all-drives-attached-vbs

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!