MacでCLIツールをインストールするときに行うターミナルでの「パスを通す」とは一体なにか?

ターミナルでなにかインストールするときに「パスを通す」作業を行います。
なんとなく理解しているつもりでしたが、人に説明できないなと思ったので、まとめて整理しておきます。
パスを通すとは何か?
「パスを通す」というのは、「特定のプログラムをプログラム名だけで実行できるようにする」ことです。
最初自分は勘違いをしていて、実行ファイルのパスを記述することだと思っていたのですが、あくまでそれは過程で、最終的なゴールは「特定のプログラムをプログラム名だけで実行できるようにする」ことです。
例えば当ブログで過去にパスを通す作業をしたツールに「anyenv」があります。
ターミナルでanyenvコマンドを使って○○env系のインストールやバージョン管理ができるものです。
しかし、インストールしただけではanyenvコマンドは使えません。
インストール先である「/opt/homebrew/bin/brew」ファイルを指定して「ここにあるファイルの、このプログラムを実行してください」と指定する必要があります。
あくまでイメージですが、実際には下記のようなコマンドになります。
/opt/homebrew/bin/brew shellenv anyenv init ○○ただこれを毎回入力するのは面倒です。
そこで、anyenvとコマンドを打ったら、指定したファイルを見てプログラムを実行するようにあらかじめ設定しておきます。
このことを「パスを通す」と言っています。
逆にパスを通していないと、anyenvコマンドを打っても「そんなコマンドは知らない」と言われてエラーになってしまいます。
パスの通し方
シェルの確認
パスを通すために必要な設定ファイルは、使っているシェルによって変わります。
使っているシェルは下記コマンドを実行すると確認できます。
echo $SHELL設定ファイルはbashでもzshでも2種類ありますが、「profile」とついている方はログイン時に1回だけ実行されて、「rc」と付いている方はログイン後にシェルを切り替えたときなどにも実行されるようです。
| シェル | 設定ファイル(ログイン時) | 設定ファイル(起動時時) | 備考 |
|---|---|---|---|
| bash | .bash_profile | .bashrc | |
| zsh | .zprofile | .zshrc |
bashの場合は「.bash_profile」に書いて、zshの場合は「.zshrc」に書くように書いている記事を見かけますが、どちらに書いてもそこまで大差なさそうです。
設定ファイルが2種類あって、微妙な違いがあることだけ覚えておきましょう。
パスの設定
設定ファイルに下記の記述をして、パスを指定します。
export PATH=$PATH:追加したいフォルダのパス記述したあとは設定をターミナルに反映する必要があります。
ターミナルを再起動するか、もしくは下記コマンド(.zshrcの部分は設定ファイルごとに変更してください)を実行すると設定ファイルの内容がターミナルに反映されます。
source .zshrcパスの設定自体はよく行うのですが、手順通りにするだけになっていました。
何が起こっているのか理解しておくことで、エラーが出たときや想定外のことが起こった場合にも対処できるようになります。
操作自体はよくしているけど、理解しきれていないようなことは、時間があるときにちゃんと調べて少しずつ理解を深めていきたいです。

CSSだけで画像の比率を保ってトリミングできる「object-fit」
WordPressって何なの?これからWordPressを勉強したい人がとりあえず知っておきたい事
Nuxt.jsの基本と最初のセットアップ「プロジェクトの作成と起動をするまでの流れ」
サイトを運営する時必ず登録しておきたいGoogle Search Console(サーチコンソール)の登録方法
WordPressのwp_is_mobile()で条件分岐をするときは、キャッシュの設定に注意
Vue CLIで共通のSCSSファイルを読み込む方法
Nuxt.jsで「Classic mode for store/ is deprecated and will be removed in Nuxt 3.」のエラーメッセージが表示される場合の対処法
JavaScriptで特定のOSやブラウザの判定を行う方法
SourceTreeで環境設定の「カスタムアクション」「アップデート」「高度な設定」が選択できない
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
1つのノートアプリにすべて集約するのをやめた理由|2025年時点のノートアプリの使い分け
Notionログイン時の「マジックリンク」「ログインコード」をやめて普通のパスワードを使う
AlfredでNotion内の検索ができるようになるワークフロー「Notion Search」
Gitで1行しか変更していないはずのに全行変更した判定になってしまう
Macでアプリごとに音量を調節できるアプリ「Background Music」
Macのターミナルでパスワード付きのZIPファイルを作成する方法
MacBook Proでディスプレイのサイズ調整をして作業スペースを広げる
SteerMouseの「自動移動」機能で保存ダイアログが表示されたら自動でデフォルトボタンへカーソルを移動させる
iPhoneでタッチが一切効かなくなった場合に強制再起動する方法