about_Environment_Provider
プロバイダー名
環境
ドライブ
Env:
機能
ShouldProcess
簡単な説明
Windows 環境変数へのアクセスを提供します。
詳しい説明
PowerShell 環境プロバイダーを使用すると、PowerShell で環境変数と値を取得、追加、変更、クリア、および削除できます。
環境変数 は、プログラムが実行される環境を記述する動的な名前付き変数です。 Windows と PowerShell では、環境変数を使用して、システムとプロセスの実行に影響を与える永続的な情報を格納します。 PowerShell 変数とは異なり、環境変数はスコープ制約の対象になりません。
環境ドライブは、現在のユーザーのセッションに固有の環境変数を含むフラット名前空間です。 環境変数には子項目がありません。
環境プロバイダーは、この記事で説明する次のコマンドレットをサポートしています。
このプロバイダーによって公開される型
各環境変数は、System.Collections.DictionaryEntry クラスのインスタンスです。 変数の名前はディクショナリ キーです。 環境変数の値はディクショナリ値です。
環境ドライブ内を移動する
環境プロバイダーは、ドライブ内のデータ ストアをEnv:
公開します。 環境変数を操作するには、場所をドライブ (Set-Location Env:
) に変更するか、別の Env:
PowerShell ドライブから作業します。 別の場所から環境変数を参照するには、パスで Env:
ドライブ名を使用します。
Set-Location Env:
ファイル システム ドライブに戻るには、ドライブ名を入力します。 たとえば、次のように入力します。
Set-Location C:
他の PowerShell ドライブから環境プロバイダーを操作することもできます。 別の場所から環境変数を参照するには、パスでドライブ名 Env:
を使用します。
環境変数プロバイダーは、変数プレフィックス$env:
を使用して環境変数も公開します。 次のコマンドは、ProgramFiles 環境変数の内容を表示します。 変数プレフィックスは $env:
、任意の PowerShell ドライブから使用できます。
PS C:\> $env:ProgramFiles
C:\Program Files
変数プレフィックスを使用して環境変数の値を $env:
変更することもできます。 行われた変更は、アクティブである限り、現在の PowerShell セッションにのみ関連します。
Note
PowerShell ではエイリアスを使用して、プロバイダー パスを使い慣れた方法で操作できます。 Get-ChildItem のエイリアスなどのdir
コマンドはls
、 cd
Set-Location のエイリアスです。 は pwd
Get-Location の エイリアスです。
環境変数の取得
このコマンドは、現在のセッション内のすべての環境変数を一覧表示します。
Get-Item -Path Env:
このコマンドは、任意の PowerShell ドライブから使用できます。
環境プロバイダーにはコンテナーがないため、上記のコマンドを使用すると同じ効果が得られます Get-ChildItem
。
Get-ChildItem -Path Env:
選択した環境変数を取得する
このコマンドは環境変数を WINDIR
取得します。
Get-ChildItem -Path Env:windir
変数プレフィックス形式も使用できます。
$env:windir
環境変数を作成する
このコマンドは、値が USERMODE
"non-管理" の環境変数を作成します。 パラメーター値により -Path
、ドライブに新しい項目が Env:
作成されます。 新しい環境変数は、アクティブである限り、現在の PowerShell セッションでのみ使用できます。
PS C:\> New-Item -Path Env: -Name USERMODE -Value Non-Admin
環境変数の変更
環境変数の名前を変更する
このコマンドでは、コマンドレットを Rename-Item
使用して、作成した USERMODE
環境変数の名前を変更します USERROLE
。 システムが使用する環境変数の名前は変更しないでください。 これらの変更は現在のセッションにのみ影響を与えますが、システムまたはプログラムの誤作動の原因になりかねません。
Rename-Item -Path Env:USERMODE -NewName USERROLE
環境変数を変更する
このコマンドでは、コマンドレットをSet-Item
使用して環境変数の値を USERROLE
"管理istrator" に変更します。
Set-Item -Path Env:USERROLE -Value Administrator
環境変数をコピーする
このコマンドは、環境変数の値を USERROLE
環境変数に USERROLE2
コピーします。
Copy-Item -Path Env:USERROLE -Destination Env:USERROLE2
環境変数を削除する
このコマンドは、現在の USERROLE2
セッションから環境変数を削除します。
Remove-Item -Path Env:USERROLE2
Clear-Item を使用して環境変数を削除する
このコマンドは、その値を USERROLE
クリアして環境変数を削除します。
Clear-Item -Path Env:USERROLE
パイプラインの使用
プロバイダー コマンドレットは、パイプライン入力を受け入れます。 パイプラインを使用すると、あるコマンドレットから別のプロバイダー コマンドレットにプロバイダー データを送信することで、タスクを簡略化できます。 プロバイダー コマンドレットでパイプラインを使用する方法の詳細については、この記事全体で提供されているコマンドレットリファレンスを参照してください。
ヘルプの表示
Windows PowerShell 3.0 より、プロバイダー コマンドレットのためにカスタマイズされたヘルプ トピックを取得できます。これはファイル システム ドライブでのプロバイダー コマンドレットの動作を説明します。
ファイル システム ドライブ用にカスタマイズされたヘルプ トピックを取得するには、ファイル システム ドライブで Get-Help コマンドを実行するか、Get-Help のパラメーターを使用-Path
してファイル システム ドライブを指定します。
Get-Help Get-ChildItem
Get-Help Get-ChildItem -Path env:
関連項目
PowerShell