Найти определенную папку в корне основного и всех подключенных дисков 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 за руководство в правильном направлении. В основном информация и код, который он дал, перечисляют все диски, которые подключены и готовы к использованию на вашем компьютере. Однако он не ищет определенную папку на каждом диске. Итак, я взял кое-что из того, что он упомянул, и
- Создан базовый файл HTA, чтобы было легче увидеть, если кто-нибудь найдет это полезным.
- Добавлена возможность поиска определенной папки на всех дисках.
- Также понял, что вы можете использовать это для поиска похожих путей к папкам на разных дисках.
Использование отмечено в 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"> </input><br></br>
<input type="button" button value="Search Folder" name="run_button" onClick="FindFolder"><br></br>
<Span Id = "DataArea"> </Span></Body>