Powershell 将一个特定文件夹解压缩到具有动态名称的文件中

Powershell Unzip One Specific Folder in a File with Dynamic Name

我发现一段代码 here 几乎可以满足我的需要,即从存档文件中提取一个文件夹。

我唯一的问题是存档名称每个月都在变化,因此我想使用通配符。一旦指定了通配符($zipfile 中的 *),该脚本就无法正常工作。

如有任何建议,我将不胜感激。

[Reflection.Assembly]::LoadWithPartialName('System.IO.Compression.FileSystem') | Out-Null

$zipfile = 'C:\ALL\Debtor*.zip'
$folder  = 'tmp\st\sd'
$dst     = 'C:\ALL\ZipOutput'

[IO.Compression.ZipFile]::OpenRead($zipfile).Entries | ? {
  $_.FullName -like "$($folder -replace '\','/')/*.*"
} | % {
 $file   = Join-Path $dst $_.FullName
 $parent = Split-Path -Parent $file
 if (-not (Test-Path -LiteralPath $parent)) {
  New-Item -Path $parent -Type Directory | Out-Null
}
[IO.Compression.ZipFileExtensions]::ExtractToFile($_, $file, $true)

试试这个尺码。只需使用 Get-ChildItem 在您的 ALL 目录中找到 zip 文件。

[Reflection.Assembly]::LoadWithPartialName('System.IO.Compression.FileSystem') | Out-Null

    $zipfile = Get-ChildItem -Path C:\ALL\ -Filter *.zip | Where-Object {$_.Name -like "Debtor*"} | Select-Object -ExpandProperty FullName
    $folder  = 'tmp\st\sd\'
    $dst     = 'C:\ALL\ZipOutput'

    [IO.Compression.ZipFile]::OpenRead($zipfile).Entries | Where-Object {
        $_.FullName -like "$($folder -replace '\','/')/*.*"
    } | ForEach-Object {
        $file   = Join-Path $dst $_.FullName
        $parent = Split-Path -Parent $file

        if(-not (Test-Path -LiteralPath $parent)) {
            New-Item -Path $parent -Type Directory | Out-Null
        }
        [IO.Compression.ZipFileExtensions]::ExtractToFile($_, $file, $true)
    }

我还假设存档名称发生了变化,但没有多个具有该名称的存档。如果有,您需要将所有内容包装在 Foreach($zip in $zipfile){ ... }