find . -type f -name "*.zip" -exec unzip {} -d {}_unzip \; This command used find to locate all zip files, and for each file found, it executed unzip with the -d option to unzip the file into a new subfolder named after the original zip file, with _unzip appended to it.
find . -type f -name "*.zip" This command found all files with the .zip extension in the current directory and its subdirectories. John then piped the output to xargs , which would execute unzip for each file found:
Best regards, John
find . -type f -name "*.zip" -print | xargs -I {} unzip {} But wait, there's a better way! John recalled that unzip has a -d option to specify the output directory. He wanted to unzip all files into their respective subfolders, without mixing files from different subfolders.
Alex was thrilled to see the unzipped files and thanked John for his help. From that day on, John was known as the "unzip master" among his colleagues. unzip all files in subfolders linux
However, instead of running unzip directly, John decided to use find to locate all the zip files first. This approach would give him more control and ensure that he only attempted to unzip files that were actually zip files.
After some more research, John discovered the perfect one-liner: -type f -name "*
find . -type f -name "*.zip" -exec unzip {} -d {}_unzip \; This command recursively found all zip files and unzipped them into their respective subfolders. Let me know if you need any further assistance.