技術メモ、Tips、忘備録

技術系のメモ、試してみたこと、その他

Windowsの環境変数「PATH」

初めに

PATHについての説明はいくらでも転がっているのですが、(いいことですが)丁寧な説明で長い記事になっているものが多く、読むのが面倒!という人のために「何ができるか」「なぜ必要なのか」を簡潔にまとめます。
それではどうぞ

PATHを通すことでできること

  • プログラムを名前だけでどこからでも実行することができる
    例:$notepad -> メモ帳()が起動します

Pathが通ったプログラムを実行するときの内部的な動き

説明

ファイル名だけをコンソールから実行した場合、

登録してあるPATHの直下にある、拡張子にPATHEXTを持つファイルを実行する
という動きになります。 また、PATHやPATHEXTは登録されている順にファイル検索が行われ、最初に一致したものを実行します。(※後で補足します)

確認

試しに、メモ帳(notepad.exe)を起動します。

$notepad

はい、起動しますね。
ちなみにnotepad.exeは二種類の実行ファイルがあります。(私の環境だけ。。?)

$where notepad
C:\Windows\System32\notepad.exe
C:\Windows\notepad.exe

$whereは検索パターンに一致するファイルの場所を表示するコマンドです。
既定では、現在のディレクトリおよび PATH 環境変数によって指定されたパス内を検索します。
先ほど実行したnotepad.exeはC:\Windows\System32\notepad.exeの方ですね。
C:\Windows\notepad.exeを実行するには、フルパスで指定してやるか、C:\Windows\の直下で$notepadを実行する必要があります。

そもそもなぜPathが必要なのか?

一つは、冒頭でも書いた通り「ファイル名だけでどこからでも実行できると便利」ということが挙げられます。
そのほかの理由として、考えられるのは、アプリケーションの開発者側が、ユーザのコンピュータのアプリケーションを実行する際にアプリケーションがどこにあるのかを意識しなくてよい、というのもあるような気がしますね。

余談

コマンドプロンプトから実行できるコマンドは何があるんだろう?」
そんな時に自分の環境でファイル名のみで利用可能なコマンドの一覧を確認したければ、powershell

foreach ($a in ($env:PATHEXT).Split(";"))
    {Start-Process -FilePath "cmd" -ArgumentList " /c where *$a >> %userprofile%\Downloads\command.txt" -Wait
}

を実行すると、%userprofile%\Downloads\command.txtに使用可能なコマンドの一覧が出力されます。
※正確には、上記で出力できるのは外部コマンドと呼ばれる類のものです。cmd.exeには組み込みコマンドというものもあり、組み込みコマンドはコマンドプロンプトhelpと打てば全量が表示されます。

・免責事項

当方は、当記事にコンテンツを掲載するにあたって、その内容、機能等について細心の注意を払っておりますが、コンテンツの内容が正確であるかどうか、最新のものであるかどうか、安全なものであるか等について保証をするものではなく、何らの責任を負うものではありません。また、当方は通知することなく当記事に掲載した情報の訂正、修正、追加、中断、削除等をいつでも行うことができるものとします。また、当記事、またはコンテンツのご利用により、万一、ご利用者様に何らかの不都合や損害が発生したとしても、当方は何らの責任を負うものではありません。