Chuyển đến nội dung chính

How to Zip (and Unzip) Files Using PowerShell

PowerShellHeader

The ZIP file format reduces the size of files by compressing them into a single file. This process saves disk space, encrypts data, and makes it easy to share files with others. Here's how to zip and unzip files using PowerShell.

How to Zip Files Using PowerShell

Let's start off by compressing some files into a ZIP file archive using the Compress-Archive cmdlet. It takes the path to any files you want to compress—multiple files are separated with a comma—and archives them in the destination you specify.

First, open PowerShell by searching for it from the Start menu and then typing in the following command, replacing <PathToFiles> and <PathToDestination> with the path to the files you want to compress and the name and folder you want it to go, respectively:

Compress-Archive -LiteralPath <PathToFiles> -DestinationPath <PathToDestination>

Zip up a few files in PowerShell.

When you provide the destination path, be sure to give the archive file a name or PowerShell will save it as ".zip" where you specify.

Note: Quotations around the path are only necessary when the file path contains a space.

Alternatively, to zip the entire contents of a folder—and all of its subfolders—you can use the following command, replacing <PathToFolder>  and <PathToDestination> with the path to the files you want to compress and the name and folder you want it to go to, respectively:

Compress-Archive -LiteralPath <PathToFolder> -DestinationPath <PathToDestination>

Zip up an entire folder and all of its contents.

In the previous example, we put the path to a directory with multiple files and folders in it without specifying individual files. PowerShell takes everything inside of the root directory and compresses it, subfolders and all.

The Compress-Archive cmdlet lets you use a wildcard character (*) to expand the functionality even further. When you use the character, you can exclude the root directory, compress only files in a directory, or choose all files of a specific type. To use a wildcard with Compress-Archive, you must use the -Path parameter instead, as -LiteralPath does not accept them.

Above, we covered how to include the root directory and all of its files and subdirectories when creating an archive file. However, if you want to exclude the root folder from the Zip file, you can use a wildcard to omit it from the archive. By adding an asterisk (*) to the end of the file path, you tell PowerShell only to grab what's inside of the root directory. It should look something like this:

Compress-Archive -Path C:pathtofile* -DestinationPath C:pathtoarchive.zip

Zip up the entire contents of a folder, without the root folder itself.

Next, say you have a folder with a bunch of different file types (.doc, .txt, .jpg, etc.) but only want to compress all of one type. You can tell PowerShell to archive them without touching the others explicitly. The command's notation would look like this:

Compress-Archive -Path C:pathtofile*.jpg -DestinationPath C:pathtoarchive.zip

Zip up only specific file types from a folder.

Note: Subdirectories and the files of the root folder aren't included in the archive with this method.

Finally, if you want an archive that only compresses files in the root directory—and all its subdirectories—you would use the star-dot-star (*.*) wildcard to zip them. It would look something like this:

Compress-Archive -Path C:pathtofile*.* -DestinationPath C:pathtoarchive.zip

Zip up only files from the root folder with the use of the widlcard star-dot-star (*.*).

Note: Subdirectories and the files of the root folder aren't included in the archive with this method.

Even after the archive is complete, you can update an existing zipped file with the use of the -Update parameter. It lets you replace older file versions in the archive with newer ones that have the same names, and add files that have been created in the root directory. It will look something like this:

Compress-Archive -Path C:pathtofiles -Update -DestinationPath C:pathtoarchive.zip

Update an already existing zip file with the use of the -Update parameter.

How to Unzip Files Using PowerShell

In addition to being able to zip files and folders, PowerShell has the ability to unzip archives. The process is even easier than compressing them; all you need is the source file and a destination for the data ready to unzip.

Open PowerShell and type in the following command, replacing <PathToZipFile> and <PathToDestination> with the path to the files you want to compress and the name and folder you want it to go to, respectively:

Expand-Archive -LiteralPath <PathToZipFile> -DestinationPath <PathToDestination>

Unzip an archive with the Expand-Archive cmdlet.

The destination folder specified to extract the files into will populate with the contents of the archive. If the folder didn't exist before unzipping, PowerShell will create the folder and place the contents into it before unzipping.

By default, if you leave out the -DestinationPath parameter, PowerShell will unzip the contents into the current root directory and use the name of the Zip file to create a new folder.

In the previous example, if we leave out -DestinationPath , PowerShell will create the folder "Archive" in the path "C:Usersbrady" and extract the files from the archive into the folder.

If you leave out the -DestinationPath parameter, PowerShell extracts the zip into its currently selected directory.

If the folder already exists in the destination, PowerShell will return an error when it tries to unzip the files. However, you can force PowerShell to overwrite the data with the new ones using the -Force parameter.

You should only use the -Force parameter if the old files are no longer needed, as this will irreversibly replace the files on your computer.

See details

Nhận xét

Popular Posts

Apple Watch Series 3 38mm Space Gray Case Black Sport Band GPS + Cellular

Apple Watch Series 3 38mm Space Gray Case Black Sport Band GPS + Cellular Price : 194.99 Ends on : 5 days View on eBay

Episode 100 - Podcasting is Dead

It’s Friday, October 30th, 2009 and welcome to episode 101 of TechTalk4Teachers! In this episode: Podcasting with 3rd Graders, an interview with Mrs. Judy Barford, Early Childhood, Elementary, and Middle Level Education Department at Eastern Illinois University Right Click Here to Download MP3 Show notes for Episode 100: Leo LaPorte’s Comment – Podcasting is Dead http://onlinedesignbureau.com/blog/116-social-media-marketing/498-leo-laporte-declares-podcasting-dead You can fast forward in the video embedded at this website to the 16 minute and 30 second mark to go directly to the “Podcasting is Dead” comments Leo made at the Online Media Association conference on October 4, 2009. No More Podcast in The New Media Expo – 2007 Podcasting is Dead Comment http://mwgblog.com/archives/2007/10/01/no-more-podcast-in-the-new-media-expo/ Also in this episode are the comments from three grad students regarding a recent podcasting assignment where the students gave their thoughts about listening t...

Episode 136 - We have the technology and we can use it

Episode 136 - We have the technology and we can use it It’s Friday, September 14, 2012 and welcome to episode 136 of Tech Talk for Teachers. I’m Cindy Rich and I’m Tom Grissom. We are changing things up a little bit. TechTalk4Teachers is moving to a bi-monthly format.     Right Click Here to Download MP3 (36 minutes 29 seconds) In this episode we talk about the all the technology available for teachers and students to use to create amazing projects. We also have a couple of useful Technology Picks of the Week. Technology Pick of the Week Tom's Pick Wacom Bamboo Pen and Touch USB Slate http://www.wacom.com/en/products/bamboo/bambootablets.aspx Cindy's Pick Hero GoPro Caneras http://gopro.com/ Keep on Learning!