Node.jsでプロジェクトルートのディレクトリを取得する方法を紹介

Node.jsでプロジェクトのルートディレクトリを取得する方法はいくつかありますが、一般的な手法を解説いたします。
__dirname
の利用
__dirname
は、スクリプトが配置されているディレクトリの絶対パスを返します。
しかし、プロジェクトのルートディレクトリを取得するには、スクリプトの場所によっては適切でない場合があります。
javascriptconsole.log(__dirname);
この方法では、実行するスクリプトのディレクトリが返るため、プロジェクトルートを確実に取得するには、
追加の処理が必要です。
process.cwd()
を利用する方法
process.cwd()
を使用すると、現在の作業ディレクトリ(カレントワーキングディレクトリ)を取得できます。
通常、プロジェクトのルートで node
コマンドを実行するため、こちらの方法が適しています。
javascriptconsole.log(process.cwd());
この方法では、Node.js を実行した場所がルートディレクトリとみなされるため、
一般的なプロジェクト構成では process.cwd()
のほうが __dirname
より便利です。
import.meta.url
を使う方法(ES Module)
ES Module (.mjs
ファイルや package.json
に "type": "module"
を設定した場合) では、 __dirname
は利用できません。
そのため、 import.meta.url
を利用し、プロジェクトのルートを求める方法があります。
javascriptimport { fileURLToPath } from 'url';
import { dirname } from 'path';
const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
console.log(__dirname);
ただし、これはスクリプトの配置されたディレクトリを取得する方法であり、
プロジェクトルートを求めるには、さらに process.cwd()
を利用するほうが適しています。
find-up
を利用したルートディレクトリの特定
より確実にプロジェクトのルートを特定したい場合は、 find-up
パッケージを使用すると便利です。
例えば、プロジェクトルートには通常 package.json
があるため、それを基準に探索できます。
find-up
のインストール
shyarn add find-up
find-up
を利用したプロジェクトルートの取得
javascriptimport { fileURLToPath } from 'url';
import { dirname } from 'path';
import findUp from 'find-up';
const projectRoot = await findUp('package.json').then(file => file ? dirname(file) : null);
console.log(projectRoot);
この方法では、 package.json
を基準にプロジェクトルートを見つけられるため、
より正確にルートディレクトリを取得できます。
まとめ
方法 | 特徴 |
---|---|
__dirname | スクリプトが配置されているディレクトリを取得 |
process.cwd() | Node.js を実行したディレクトリ(一般的にはプロジェクトルート)を取得 |
import.meta.url | ES Module 環境でスクリプトディレクトリを取得 |
find-up | package.json などを基準にプロジェクトルートを検索 |
一般的には process.cwd()
を使うのが簡単で便利ですが、
プロジェクトの構成によって find-up
を用いるとより確実にルートを特定できます。
適切な方法を選択し、Node.js のプロジェクト管理をより効率的に進めてください。
記事Article
もっと見る- article
NestJSでバリデーションエラーをログ出力する設定を紹介
- article
NestJSで作成したAPIのレスポンスヘッダーに付与されるx-powered-by: Express を消す方法を紹介
- article
Next.jsで環境変数に別の変数を利用し柔軟に管理するdotenv-expandの活用法を紹介
- article
【2025年3月版】Cursor ProとAPI利用比較。 Claude・GPT-4o・o1・GPT-4.5の損益分岐点と選び方
- article
フォーム入力情報からZodを利用してDTO作成しへ変換処理を実施するやり方を紹介
- article
Zodバリデーションのエラーメッセージを日本語化すやり方を紹介