タイトル: pwd カレントディレクトリの表示
SEOタイトル: pwd コマンド完全ガイド(-P / -L オプション、$PWD / $OLDPWD、Windows 対応)
| この記事の要点 |
|
基本
# 現在のディレクトリを表示
pwd
# /home/user/projects/myapp
# シェル変数でも取得可能
echo $PWD
# /home/user/projects/myapp
# 直前のディレクトリ
echo $OLDPWD
# /home/user
# 直前のディレクトリに戻る
cd -
オプション: -P と -L
シンボリックリンクを含むパスでは挙動が分かれます:
# 準備: /var/www → /home/user/web というシンボリックリンクがあるとする
ln -s /home/user/web /var/www
cd /var/www
# 既定(-L 論理): リンクのまま
pwd
# /var/www
pwd -L
# /var/www
# -P 物理: リンク解決
pwd -P
# /home/user/web
# realpath / readlink で確認
realpath .
# /home/user/web
readlink -f .
# /home/user/web
| オプション | 動作 | 用途 |
|---|---|---|
なし / -L | 論理パス(シンボリックリンク含む) | ユーザーが cd したパスのまま |
-P | 物理パス(リンクを解決) | ファイルの実体位置を確認 |
-help | ヘルプ表示(bash builtin) | — |
$PWD / $OLDPWD 環境変数
# $PWD は cd ごとに自動更新
cd /tmp
echo $PWD # /tmp
# $OLDPWD は直前のディレクトリ
cd /var/log
echo $PWD # /var/log
echo $OLDPWD # /tmp
# cd - で OLDPWD に戻る(pwd 表示付き)
cd - # /tmp
cd - # /var/log(再びトグル)
# スクリプト内で安全に取得
CURRENT=$(pwd)
echo "現在: $CURRENT"
# サブシェルでディレクトリ変更しても親に影響しない
(cd /tmp && pwd) # /tmp
pwd # 元のディレクトリ
シェルビルトインと外部コマンド
# どの pwd が呼ばれているか
type pwd
# pwd is a shell builtin
# 外部コマンドを明示的に呼ぶ
/bin/pwd
/bin/pwd -P
# builtin / 外部の違いを比較
command -V pwd
which pwd
# /usr/bin/pwd
通常はシェル組み込みの方が高速。シンボリックリンク解決の挙動は概ね同じです。
スクリプトでの定型パターン
#!/bin/bash
# スクリプト自身の場所(実行位置と無関係)
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
echo "スクリプトの場所: $SCRIPT_DIR"
# 実行時の作業ディレクトリ
echo "呼び出されたディレクトリ: $(pwd)"
# プロジェクトルートに移動して作業
cd "$SCRIPT_DIR/.." || exit 1
pwd
# 一時的にディレクトリを移動して戻る
pushd /tmp > /dev/null
# ... /tmp で作業 ...
popd > /dev/null
# サブシェルで囲む(より安全)
(
cd /var/log
pwd
ls
)
# 親シェルのカレントは変わらない
pwd
プロンプトに pwd を埋め込む
# ~/.bashrc
# フルパス
export PS1='\u@\h:\w$ '
# user@host:/home/user/projects$
# 末尾だけ(basename)
export PS1='\u@\h:\W$ '
# user@host:projects$
# 物理パスを表示
export PS1='\u@\h:$(pwd -P)$ '
# zsh
export PROMPT='%n@%m %~ %# '
Windows での同等コマンド
| 環境 | コマンド | 備考 |
|---|---|---|
| PowerShell | Get-Location / pwd (alias) / gl | pwd は別名でビルトイン |
| cmd.exe | cd(引数なし) / echo %CD% | %CD% は環境変数 |
| WSL | pwd | Linux と同じ |
| Git Bash | pwd | pwd -W で Windows パス表示 |
# PowerShell
Get-Location
# Path
# ----
# C:\Users\you\projects
pwd # 別名
gl # 短縮別名
# パス文字列のみ
(Get-Location).Path
$PWD.Path
# 戻り値の型
$PWD.GetType() # System.Management.Automation.PathInfo:: Windows cmd.exe
cd
:: C:\Users\you\projects
echo %CD%
:: C:\Users\you\projects
:: バッチファイル内で
@echo off
echo Current: %CD%
echo Script: %~dp0
Git Bash の特殊オプション
# Git Bash (MSYS) では Windows パス変換が可能
cd /c/Users/you/projects
pwd
# /c/Users/you/projects
pwd -W # Windows 形式
# C:/Users/you/projects
よくある質問・トラブル
| 状況 | 原因・対処 |
|---|---|
pwd が (unreachable) を含む | cd した後にディレクトリが削除された、別ターミナルで再度 cd |
cron / systemd で pwd が / | cron は / または HOME で起動、スクリプト先頭で cd |
| symlink で混乱 | pwd -P で実体確認、realpath . でも可 |
| スクリプト相対パスが壊れる | SCRIPT_DIR=$(cd "$(dirname "$0")"; pwd) |
FAQ
Q: pwd と $PWD、どちらが速い?
A: $PWD は変数参照のみで最速。スクリプト内で多用するなら $PWD が好まれます。
Q: cd /tmp したのに pwd が違う
A: /tmp がシンボリックリンクの可能性。pwd -P で実体を確認。
Q: cron で pwd が変なディレクトリ
A: cron はユーザー HOME を作業ディレクトリにします。スクリプトの先頭で必ず cd /path/to/work。
関連コマンド
cd— ディレクトリ移動pushd/popd— スタック式ディレクトリ移動dirs -v— pushd スタック確認realpath/readlink -f— シンボリックリンク解決basename/dirname— パス分解