I am creating a nightly database schema file and would like to put all the files created each night, one for each database, into a folder and compress that folder. I have a PowerShell script that creates the schema.Only creation script of the db's and then adds all the files to a new folder. The problem lies within the compression portion of this process.
Does anybody have any idea if this can be accomplished with the pre-installed Windows utility that handles folder compression?
It would be best to use that utility if possible rather than something like 7zip (I don't feel like installing 7zip on every customers' server and it may take IT years to do it if I ask them).
Used voithos' answer to zip files up in powershell, just had one problem with the Add-Zip function, the Start-sleep -milliseconds 500 caused problems if the file couldn't be fully zipped up in that time -> the next one starting before it was complete caused errors and some files not to be zipped.
So after playing around for a bit, first trying to get a counter going to check the count of the $zipPackage.Items() and only continuing after the items count increased (which did not work as it would return 0 in some cases when it should not) I found that it will return 0 if the package is still zipping/copying the files up (I think, haha). Added a simple while loop with the start-sleep inside of it, waiting for the zipPackage.Items().count to be a non-zero value before continuing and this seems to solve the problem.
Using PowerShell Version 3.0:
Hope this helps.
This compresses .\in contents to .\out.zip with System.IO.Packaging.ZipPackage following the example here
A native way with latest .NET 4.5 framework, but entirely feature-less:
Creation:
Extraction:
As mentioned, totally feature-less, so don't expect an overwrite flag.
As of PowersShell 5 there is a Compress-Archive cmdlet that does the task out of the box.
Here's a couple of zip-related functions that don't rely on extensions: Compress Files with Windows PowerShell.
The main function that you'd likely be interested in is:
Usage:
There is one caveat: the
shell.application
object'sNameSpace()
function fails to open up the zip file for writing if the path isn't absolute. So, if you passed a relative path toAdd-Zip
, it'll fail with a null error, so the path to the zip file must be absolute.Or you could just add a
$zipfilename = resolve-path $zipfilename
at the beginning of the function.