为了下载文件,Invoke-WebRequest 不是最佳方式,因为 HTTP 响应流被缓冲到内存中,并且一旦文件被完全加载,那么只有它会被刷新到磁盘。如果文件很大,这可能会影响性能。
我建议您使用System.Net.WebClient DotNET 类从您的 GitHub 源下载文件。您可以将代码重构为以下内容:
$url = "http://github.com/zip.zip"
$output = "C:\SomePath\zip.zip"
(New-Object System.Net.WebClient).DownloadFile($url, $output)
这个 cmdlet 与 Invoke-WebRequest 相比有何优势?你可能会问。
使用 System.Net.WebClient,速度/性能得到很大提高,因为 HTTP 响应流在整个下载过程中直接缓冲到磁盘(而不是将工作拆分为获取和刷新任务)。
注意:确保本地输出文件(您在 $output 中为其提供路径)是有效文件并且存在,否则在使用 DownloadFile 方法时可能会出错.
更新:
由于上述解决方案在压缩文件的情况下似乎无法按预期工作,这里有另一种解决方法,可用于使用 PowerShell 实现此目的:
$url = "http://github.com/zip.zip"
$zipOutput = "C:\ZipOutput\" + $(Split-Path -Path $url -Leaf)
$extractedOutput = "C:\ExtractedOutput\"
(New-Object System.Net.WebClient).DownloadFile($url, $zipOutput)
$shellObj = New-Object -ComObject Shell.Application
$files = $shellObj.Namespace($zipOutput).Items()
$shellObj.NameSpace($extractedOutput).CopyHere($files)
Start-Process $extractedOutput
zip 文件将被下载到$zipOutput 提供的路径,脚本将进一步提取内容并将提取的内容存储在$extractedOutput 提供的路径中。确保执行此脚本的计算机上存在“C:\ZipOutput”和“C:\ExtractedOutput”文件夹。