在主目录和所有附加驱动器的根目录中查找特定文件夹 vbs
Find Specific Folder in Root of main and all drives attached vbs
我想查找一个特定的文件夹,该文件夹可能位于 Windows 7 机器的主驱动器的根目录中,或者位于与之相连的任何 USB 驱动器的根目录中。我更愿意使用 vbscript 在 vbscript 或 hta(不是 htaaccess)中执行此操作。
例如。我需要找到文件夹 "xyz"。它可能在这里:C:\xyz 或 D:\xyz 或 Z:\xyz 等。我不在乎它是否在这里:c:\Users\Joe\xyz 或 F:\folder1\xyz.
我认为如果搜索集中在每个驱动器的根文件夹中,搜索会相当快。
来自帮助
所有可用驱动器的只读集合。
备注
可移动媒体驱动器无需插入媒体即可出现在驱动器集合中。
以下示例说明了如何使用 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 集合没有方法。
属性
计数 属性 |项目 属性
另请参阅
参考
驱动对象
驱动器 属性
文件对象
文件收集
文件夹对象
文件夹集合
感谢@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>
这个 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
'**********************************************************************************************
我想查找一个特定的文件夹,该文件夹可能位于 Windows 7 机器的主驱动器的根目录中,或者位于与之相连的任何 USB 驱动器的根目录中。我更愿意使用 vbscript 在 vbscript 或 hta(不是 htaaccess)中执行此操作。
例如。我需要找到文件夹 "xyz"。它可能在这里:C:\xyz 或 D:\xyz 或 Z:\xyz 等。我不在乎它是否在这里:c:\Users\Joe\xyz 或 F:\folder1\xyz.
我认为如果搜索集中在每个驱动器的根文件夹中,搜索会相当快。
来自帮助
所有可用驱动器的只读集合。
备注 可移动媒体驱动器无需插入媒体即可出现在驱动器集合中。
以下示例说明了如何使用 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 集合没有方法。
属性 计数 属性 |项目 属性
另请参阅 参考 驱动对象 驱动器 属性 文件对象 文件收集 文件夹对象 文件夹集合
感谢@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>
这个 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
'**********************************************************************************************