Unzip All Files In Subfolders Linux Guide
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 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. unzip all files in subfolders linux
find . -name "*.zip" -type f -print0 | xargs -0 -I {} sh -c 'unzip -o "{}" -d "$(dirname "{}")"' The -exec option runs unzip once per file. xargs groups multiple file paths into a single command, reducing process overhead. The -print0 and -0 handle filenames with spaces or special characters safely. Method 3: Pure Bash Loop (Most Readable) If you prefer clarity over brevity: xargs groups multiple file paths into a single
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: use a loop: