I want to iterate among sub directories of my current location and gzip each file seperately. For zipping files in a directory, I use
for file in *; do gzip "$file"; done
but this can just work on current directory and not the sub directories of the current directory. How can I rewrite the above statements so that It also zips the files in all subdirectories?
How to recursively compress files using gzip? To recursively compress files, use the -r command line option. This option, as the name suggests, will compress files in the main directory as well as all subdirectories. So you can see that all files - whether in main directory or subdirectory - were compressed.
To compress multiple files at once using gzip , we use the gzip command with -d option followed by file names to be decompressed separated by a space.
No need for loops or anything more than find and gzip:
find . -type f ! -name '*.gz' -exec gzip "{}" \;
This finds all regular files in and below the current directory whose names don't end with the .gz extension (that is, all files that are not already compressed).  It invokes gzip on each file individually.
Edit, based on comment from user unknown:
The curly braces ({}) are replaced with the filename, which is passed directly, as a single word, to the command following -exec as you can see here:
$ touch foo
$ touch "bar baz"
$ touch xyzzy
$ find . -exec echo {} \;
./foo
./bar baz
./xyzzy
I'd prefer gzip -r ./ which does the same thing but is shorter.
find . -type f | while read file; do gzip "$file"; done
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With