在主的根和所有驱动器附加vbs中查找特定文件夹

时间:2015-02-07 02:35:02

标签: windows vbscript hta

我想查找一个特定文件夹,该文件夹可能位于Windows 7计算机主驱动器的根目录下,也可能位于连接到它的任何USB驱动器的根目录下。我更喜欢使用vbscript在vbscript或hta(而不是htaac​​cess)中执行此操作。

离。我需要找到文件夹" xyz"。它可以在这里:C:\ xyz或D:\ xyz或Z:\ xyz等。我不在乎它是否在这里:c:\ Users \ Joe \ xyz或F:\ folder1 \ XYZ。

如果搜索集中在每个驱动器的根文件夹中,我认为搜索速度相当快。

3 个答案:

答案 0 :(得分:2)

来自帮助

所有可用驱动器的只读集合。

备注 可移动介质驱动器无需插入介质即可显示在Drives集合中。

以下示例说明了如何使用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集合没有方法。

属性 伯爵财产|物品属性

另见 参考 驱动对象 驱动财产 文件对象 文件集合 文件夹对象 文件夹集合

答案 1 :(得分:2)

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

答案 2 :(得分:1)

感谢@ user4532213带领我朝着正确的方向前进。基本上,他提供的信息和代码列出了连接并准备在您的计算机上使用的所有驱动器。但是,它不会在每个驱动器上查找特定文件夹。所以,我采取了他提到的一些内容和

  1. 创建了一个基本的HTA文件,以便于查看是否有人认为这有用。
  2. 添加了搜索所有驱动器上特定文件夹的功能。
  3. 还意识到您可以使用它在不同的驱动器上搜索类似的文件夹路径。
  4. 在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>