この内容は古いバージョンです。最新バージョンを表示するには、戻るボタンを押してください。
バージョン:5
ページ更新者:atom
更新日時:2026-06-11 07:10:02

タイトル: pwd カレントディレクトリの表示
SEOタイトル: pwd コマンド完全ガイド(-P / -L オプション、$PWD / $OLDPWD、Windows 対応)

この記事の要点
  • pwd(print working directory)は現在の作業ディレクトリを表示する Unix/Linux 標準コマンド
  • pwd -P: 物理パス(シンボリックリンクを解決)、pwd -L: 論理パス(リンクのまま、既定)
  • 環境変数: $PWD = 現在のディレクトリ、$OLDPWD = 直前のディレクトリ
  • シェルビルトインと /bin/pwd が存在、type pwd で確認
  • Windows PowerShell: Get-Location / 別名 pwd、cmd は cd(引数なし)または echo %CD%

基本

# 現在のディレクトリを表示
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 での同等コマンド

環境コマンド備考
PowerShellGet-Location / pwd (alias) / glpwd は別名でビルトイン
cmd.execd(引数なし) / echo %CD%%CD% は環境変数
WSLpwdLinux と同じ
Git Bashpwdpwd -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 — パス分解