【问题标题】:How to traverse subfolders in a zip file and unzip files with specific extension?如何遍历 zip 文件中的子文件夹并解压缩具有特定扩展名的文件?
【发布时间】:2015-05-13 20:02:18
【问题描述】:

基本上我正在尝试将一些特定文件解压缩到一个 zip 文件中(其中有很多垃圾子文件夹)。

问题是只有最后一个子文件夹包含我想要的文件。其他子文件夹不会包含除另一个子文件夹之外的任何文件。

这是我目前正在使用的代码:

ZipFile="C:\Test.zip" 
ExtractTo="C:\" 
Set fso = CreateObject("Scripting.FileSystemObject") 
If NOT fso.FolderExists(ExtractTo) Then  
    fso.CreateFolder(ExtractTo) 
End If 
set objShell = CreateObject("Shell.Application") 
set FilesInZip= objShell.NameSpace(ZipFile).items
print "There are " & FilesInZip.Count & " files" 
'Output will be 1 because there is only one subfolder there.
objShell.NameSpace(ExtractTo).CopyHere(FilesInZip) 
Set fso = Nothing 
Set objShell = Nothing

无论如何我可以遍历子文件夹并仅解压缩具有特定扩展名的文件吗?

【问题讨论】:

    标签: vbscript


    【解决方案1】:

    您可以使用递归过程来执行此操作,该过程为文件夹项目调用自身并提取具有特定扩展名的文件项目:

    Set fso = CreateObject("Scripting.FileSystemObject")
    Set app = CreateObject("Shell.Application")
    
    Sub ExtractByExtension(fldr, ext, dst)
      For Each f In fldr.Items
        If f.Type = "File folder" Then
          ExtractByExtension f.GetFolder, ext, dst
        ElseIf LCase(fso.GetExtensionName(f.Name)) = LCase(ext) Then
          app.NameSpace(dst).CopyHere f.Path
        End If
      Next
    End Sub
    
    ExtractByExtension app.NameSpace("C:\path\to\your.zip"), "txt", "C:\output"
    

    【讨论】:

      猜你喜欢
      • 2019-03-02
      • 2018-07-25
      • 2020-01-07
      • 2015-04-05
      • 1970-01-01
      • 1970-01-01
      • 2016-01-10
      • 1970-01-01
      • 2020-05-02
      相关资源
      最近更新 更多