6.

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 — パス分解
編集
Post Share
子ページ

子ページはありません

同階層のページ
  1. ls ファイル/ディレクトリ一覧表示
  2. sudo ユーザー指定
  3. cron/crontab ジョブの自動実行と登録方法
  4. wget http通信によるファイルダウンロード
  5. rm ファイル/ディレクトリ削除
  6. pwd カレントディレクトリの表示
  7. cd ディレクトリの移動
  8. ./configure
  9. make
  10. make install
  11. unzip ファイルの解凍
  12. mv ファイル/ディレクトリの移動および名称変更
  13. mkdir ディレクトリの作成
  14. touch 空ファイルの新規作成
  15. vi テキストディタの使用
  16. find ファイル/ディレクトリ検索
  17. grep 文字列の検索
  18. tail ファイルの末尾表示
  19. curl HTTP通信によるリクエスト
  20. nslookup ドメインのIP解決
  21. apt update パッケージリストの情報を更新
  22. apt upgrade パッケージの更新
  23. ln リンク/ショートカットの作成と削除
  24. rsync ファイル/ディレクトリの同期
  25. ssh リモートとの暗号化通信
  26. scp sshを利用したファイルのコピー
  27. unzip zip ファイルを解凍する
  28. cp ファイル/ディレクトリのコピー
  29. diffファイルの差分抽出
  30. fdisk ハードディスクに対する操作
  31. lsblk デバイスをツリー状で表示する
  32. kill プロセスを終了させる
  33. zip ファイルやディレクトリをzip形式に圧縮する
  34. host ドメインからIPアドレスを確認
  35. chmod 権限の変更
  36. ip IPアドレスの確認
  37. chown ファイル/ディレクトリ所有者の変更
  38. chgrp ファイル/ディレクトリのグループ情報の変更
  39. nohupと'&' プログラムのバックグラウンド実行(ssh接続時)
  40. lsof 開いているポート番号の確認
  41. tar ファイルの圧縮と解凍
  42. file ファイルの種類を表示
  43. cat ファイルの中身を表示
  44. head ファイルの先頭部分を表示
  45. wc 行数/単語数/文字数を確認
  46. shutdown システムのシャットダウンと再起動
  47. ps プロセスの確認
  48. which コマンドの絶対パスを調べる
  49. yum RedHat系ディストリビューションの管理
  50. mount ファイルシステムのマウント
  51. 特定フォルダ以下の特定拡張子のファイルを再帰的に削除する方法
  52. 特定のフォルダとそのサブフォルダ内にある特定のファイル名のファイルを再帰的に削除