Найти определенную папку в корне основного и всех подключенных дисков VBS

Я хотел бы найти определенную папку, которая может находиться в корне основного диска Windows 7 Machine или в корне любых USB-накопителей, подключенных к нему. Я бы предпочел сделать это в vbscript или в hta (не htaaccess), используя vbscript.

ех. Мне нужно найти папку "XYZ". Это может быть здесь: C: \ xyz или D: \ xyz или Z: \ xyz и т. Д. Мне все равно, находится ли он здесь: c: \ Users \ Joe \ xyz или F: \ folder1 \ xyz.

Я полагаю, что поиск будет довольно быстрым, если поиск будет сосредоточен только на корневых папках каждого диска.

3 ответа

Решение

Этот vbscript может искать папку на всех ваших подключенных дисках, поэтому я добавляю панель ожидания, чтобы позволить пользователю набраться терпения, пока он не закончит свою работу

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
'**********************************************************************************************

Из справки

Коллекция только для чтения всех доступных дисков.

Примечания Для накопителей на съемных носителях не требуется вставлять носители, чтобы они отображались в коллекции накопителей.

В следующем примере показано, как получить коллекцию Drives с помощью свойства Drives и выполнить итерацию коллекции:

Сценарий копирования кода Visual Basic Функция 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

Методы У коллекции Drives нет методов.

Недвижимость Count Недвижимость | Свойство объекта

См. Также Справка. Дисководы объектов дисков.

Спасибо @user4532213 за руководство в правильном направлении. В основном информация и код, который он дал, перечисляют все диски, которые подключены и готовы к использованию на вашем компьютере. Однако он не ищет определенную папку на каждом диске. Итак, я взял кое-что из того, что он упомянул, и

  1. Создан базовый файл HTA, чтобы было легче увидеть, если кто-нибудь найдет это полезным.
  2. Добавлена ​​возможность поиска определенной папки на всех дисках.
  3. Также понял, что вы можете использовать это для поиска похожих путей к папкам на разных дисках.

Использование отмечено в 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>

Другие вопросы по тегам