タイトル: unzip zip ファイルを解凍する
SEOタイトル: Linux unzip コマンド完全ガイド — zip ファイル解凍 / 出力先 / パスワード / 文字化け対処
| この記事の要点 |
|
unzip とは
unzip は .zip 形式のファイルを展開する CLI コマンドです。Linux / macOS / WSL では標準搭載か apt install unzip ですぐ使えます。Windows ではエクスプローラの右クリック展開や PowerShell Expand-Archive が代替手段になります。
# インストール
sudo apt install -y unzip zip # Debian/Ubuntu
sudo yum install -y unzip zip # RHEL/CentOS
brew install unzip # macOS (標準で入っているが新版)
基本: zip を解凍する
# カレントディレクトリに解凍
unzip file.zip
# 出力先を指定 (推奨)
unzip file.zip -d ./extracted/
# 静粛モード (詳細表示なし)
unzip -q file.zip -d ./dest/
# 強制上書き (確認なし)
unzip -o file.zip
# 既存ファイルがあればスキップ
unzip -n file.zip
主要オプション一覧
| オプション | 意味 | 使用例 |
|---|---|---|
-d DIR | 展開先ディレクトリを指定 | unzip a.zip -d /tmp/out |
-l | 展開せず中身一覧を表示 | unzip -l a.zip |
-v | 詳細表示 (圧縮率も) | unzip -v a.zip |
-q | 静粛モード | unzip -q a.zip |
-o | 確認なしで上書き | unzip -o a.zip |
-n | 上書きしない | unzip -n a.zip |
-P PASS | パスワード付き zip | unzip -P secret a.zip |
-O CHARSET | ファイル名エンコーディング | unzip -O cp932 a.zip |
-j | ディレクトリ構造を無視 | unzip -j a.zip |
-t | 整合性チェック (展開しない) | unzip -t a.zip |
中身を確認してから展開
展開する前に中身を確認するのは安全運用の基本です:
# 一覧表示
unzip -l archive.zip
# Archive: archive.zip
# Length Date Time Name
# --------- ---------- ----- ----
# 142 2026-05-17 10:00 README.md
# 35420 2026-05-17 10:01 src/index.js
# --------- -------
# 35562 2 files
# 圧縮率も含めた詳細
unzip -v archive.zip
# 整合性チェック (壊れていないか)
unzip -t archive.zip
# → No errors detected in compressed data of archive.zip.
日本語ファイル名の文字化け対策
Windows で作成された zip はファイル名が Shift_JIS (CP932) で格納されていることが多く、Linux で解凍すると文字化けします:
# ❌ 文字化け
unzip windows.zip
# → ã??ã?¥ã?¡ã?³ã??.txt (文字化け)
# ✅ CP932 を指定 (unzip が -O 対応版なら)
unzip -O cp932 windows.zip
# unzip が古い場合: 7z で展開
7z x windows.zip
# Python で展開 (確実)
python3 -c "
import zipfile
with zipfile.ZipFile('windows.zip') as z:
for info in z.infolist():
info.filename = info.filename.encode('cp437').decode('cp932')
z.extract(info)
"
パスワード付き zip
# 解凍時にパスワード指定 (履歴に残る)
unzip -P secret protected.zip
# プロンプトで入力 (安全)
unzip protected.zip
# [protected.zip] foo.txt password: ********
# 作成時にパスワード設定
zip -er encrypted.zip secret-dir/ # AES256
zip -P pass -r weak.zip dir/ # 弱い ZipCrypto (推奨しない)
zip 作成: zip コマンド
# 単一ファイル
zip out.zip file.txt
# ディレクトリ再帰的に
zip -r out.zip target-dir/
# 圧縮レベル指定 (0-9, デフォルト 6)
zip -9 -r out.zip dir/ # 最高圧縮
# 除外
zip -r out.zip dir/ -x "*.log" "*.tmp" ".git/*"
# 分割 (100MB ずつ)
zip -r -s 100m out.zip big-dir/
# → out.zip out.z01 out.z02 ...
# 既存 zip に追加
zip -u out.zip new-file.txt
zip vs tar.gz の使い分け
| 項目 | zip | tar.gz |
|---|---|---|
| 互換性 | Windows と相性◎ | Linux/macOS 標準 |
| 圧縮率 | ファイル単位 (やや低い) | アーカイブ全体 (高い) |
| パーミッション保持 | 限定的 | 完全 (uid/gid も) |
| シンボリックリンク | 不完全 | 完全 |
| 暗号化 | 標準対応 (-e) | 標準では非対応 (gpg 併用) |
| 分割 | 標準対応 (-s) | split コマンド併用 |
# tar.gz の作成
tar -czvf out.tar.gz target-dir/
# tar.gz の展開
tar -xzvf out.tar.gz
# zip を tar.gz に変換
unzip -q in.zip -d ./tmp/ && tar -czf out.tar.gz -C ./tmp/ .
Windows での解凍
# PowerShell 5.0+ 標準コマンド
Expand-Archive -Path .\file.zip -DestinationPath .\extracted
# 強制上書き
Expand-Archive -Path .\file.zip -DestinationPath .\dest -Force
# 圧縮
Compress-Archive -Path .\src\* -DestinationPath .\out.zip
# 7-Zip CLI (高機能、日本語 OK)
7z x file.zip -odest # 展開 (-o の後にスペース不可)
7z l file.zip # 一覧
7z a -tzip out.zip src/ # 作成
7z a -p secret out.zip src/ # パスワード付き
典型的なエラーと対処
| エラー | 原因 | 対処 |
|---|---|---|
End-of-central-directory signature not found | ファイル破損 | 再ダウンロード / zip -FF in.zip --out fixed.zip |
cannot find or open file.zip | パス誤り | 絶対パスで指定 |
filename: mismatching "local" filename | 文字コード問題 | -O cp932 指定 |
need PK compat. v4.5 (can do v2.1) | 古い unzip | p7zip-full / unzip 更新 |
FAQ
Q: macOS の標準解凍と挙動が違う
A: macOS Finder は内部で BOMArchiveHelper を使い文字コードを推定します。CLI unzip で文字化けする場合は brew install p7zip で 7z x を使うのが確実。
Q: 大量の小ファイルを zip するのが遅い
A: tar (パイプで gzip) のほうが速いことが多い。圧縮を求めないなら tar -cf (圧縮なし) が最速。
Q: ZipSlip 脆弱性が心配
A: 信頼できない zip を展開する前に unzip -l で ../ を含むパスがないか必ず確認。Java/Node のライブラリは要パッチ。