If you’ve ever downloaded a large dataset, a batch of game mods, or a collection of ebooks on Linux, you’ve likely encountered the same frustrating scenario: a parent folder filled with dozens (or hundreds) of subfolders, each containing one or more .zip archives. Opening each subfolder, right-clicking, and extracting manually is tedious, error-prone, and completely against the Linux philosophy of automation.
cd ~/Downloads/course find . -name "*.zip" -type f -exec unzip -n {} -d {}/.. \; The -n (never overwrite) protects already-extracted content. For repeated use, save this script as unzip-all.sh : unzip all files in subfolders linux
find . -name "*.zip" -type f | while read -r zipfile; do target_dir=$(dirname "$zipfile") unzip -o "$zipfile" -d "$target_dir" done This simple loop breaks if filenames contain newlines. For production scripts, use the -print0 and while IFS= read -r -d '' pattern: If you’ve ever downloaded a large dataset, a
find . -name "*.zip" -type f -exec unzip -o {} -d /path/to/target \; This extracts every ZIP directly into /path/to/target . If two ZIPs contain a file with the same name, the last one extracted overwrites the previous. Method 5: Recursive Unzipping (ZIPs inside ZIPs) What if some of those ZIP files themselves contain other ZIP files? The command above only extracts one level. To recursively extract until no ZIPs remain, use a loop: -name "*
find . -name "*.zip" -exec unzip -t {} \; Imagine you downloaded a course bundle: ~/Downloads/course/ with subfolders week1/data.zip , week2/slides.zip , week3/exercises.zip . You want to extract each into its respective folder without overwriting existing files.