環境変数PATHの設定は、旧コマンドプロンプトにしか影響しないことがわかりました。PowerShellは環境設定が異なるようです。PowerShell(v1)の環境変数を変更するにはどうすればよいのでしょうか?
注意してください。
PowerShellを実行するたびに設定する必要がないように、変更を恒久的にしたいのですが。PowerShellにプロファイルファイルはありますか?UnixのBashプロファイルのようなものですか?
実際の環境変数を変更するには env: namespace / drive` の情報を使用します。例えば、次の のコードはパス環境変数を更新します。
$env:Path = "SomeRandomPath"; (replaces existing path)
$env:Path += ";SomeRandomPath" (appends to existing path)
環境設定を永続的にする方法はありますが PowerShell からしか使用しないのであれば、プロファイルを使用して環境設定を開始した方が良いでしょう。 プロファイルを使用して設定を開始する方がはるかによいでしょう。 設定を開始するためにプロファイルを使用する方がずっと良いでしょう。起動時に、PowerShell は `WindowsPP1' にある .ps1 ファイルをすべて実行します。 ファイルを実行します。 ディレクトリにある .ps1 ファイルを実行します。一般的には、profile.ps1* ファイルがすでに存在します。 ファイルがすでにあります。私のコンピュータのパスは次のとおりです。
C:\Users\JaredPar\Documents\WindowsPowerShell\profile.ps1
また、以下の方法でユーザー/システム環境変数を permanently (シェルの再起動の間、永続的に) 変更することも可能です。
システム環境変数を変更する
[Environment]::SetEnvironmentVariable
("Path", $env:Path, [System.EnvironmentVariableTarget]::Machine)
ユーザ環境変数の変更
[Environment]::SetEnvironmentVariable
("INCLUDE", $env:INCLUDE, [System.EnvironmentVariableTarget]::User)
コメントからの使用法 - システム環境変数に追加する
[Environment]::SetEnvironmentVariable(
"Path",
[Environment]::GetEnvironmentVariable("Path", [EnvironmentVariableTarget]::Machine) + ";C:\bin",
[EnvironmentVariableTarget]::Machine)
型を書きたくない場合は、文字列ベースの解決策も可能です。
[Environment]::SetEnvironmentVariable("Path", $env:Path + ";C:\bin", "Machine")
PowerShellプロンプトから:
setx PATH "$env:path;\the\directory\to\add" -m
次に、テキストが表示されます。
SUCCESS: Specified value was saved.
セッションを再起動すると、変数が利用可能になります。 setx
は、任意変数の設定にも使用できます。 setx /と入力します?
ドキュメントのプロンプトで。
この方法でパスをいじる前に、 $ env:path>>を実行して、既存のパスのコピーを保存してください。 PowerShellプロンプトのa.out
。
JeanTの回答のように、パスに追加することについての抽象化が必要でした。 JeanTの回答とは異なり、ユーザーの操作なしで実行する必要がありました。 私が探していた他の行動:
$ env:Path
を更新して、変更が現在のセッションで有効になるようにします。
-今後のセッションでは、環境変数の変化を維持します。
-同じパスがすでに存在する場合は、重複したパスを追加しません。便利な場合は、こちらをご覧ください。
function Add-EnvPath {
param(
[Parameter(Mandatory=$true)]
[string] $Path,
[ValidateSet('Machine', 'User', 'Session')]
[string] $Container = 'Session'
)
if ($Container -ne 'Session') {
$containerMapping = @{
Machine = [EnvironmentVariableTarget]::Machine
User = [EnvironmentVariableTarget]::User
}
$containerType = $containerMapping[$Container]
$persistedPaths = [Environment]::GetEnvironmentVariable('Path', $containerType) -split ';'
if ($persistedPaths -notcontains $Path) {
$persistedPaths = $persistedPaths + $Path | where { $_ }
[Environment]::SetEnvironmentVariable('Path', $persistedPaths -join ';', $containerType)
}
}
$envPaths = $env:Path -split ';'
if ($envPaths -notcontains $Path) {
$envPaths = $envPaths + $Path | where { $_ }
$env:Path = $envPaths -join ';'
}
}
対応する「Remove-EnvPath」関数については、my gistをチェックしてください。
現在受け入れられている回答は、パス変数がPowerShellのコンテキストから永続的に更新されるという意味で機能しますが、実際にはWindowsレジストリに保存されている環境変数を更新しません。
これを実現するには、PowerShellも使用できます。
$oldPath=(Get-ItemProperty -Path 'Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment' -Name PATH).Path
$newPath=$oldPath+’;C:\NewFolderToAddToTheList\’
Set-ItemProperty -Path 'Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment' -Name PATH –Value $newPath
詳細については、ブログ投稿 PowerShellを使用して環境パスを変更 を参照してください。
PowerShellコミュニティ拡張機能を使用する場合、環境変数パスにパスを追加する適切なコマンドは次のとおりです。
Add-PathVariable "C:\NewFolderToAddToTheList" -Target Machine
永続的な変更を示唆するすべての回答には同じ問題があります。それらはパスレジストリ値を破ります。
SetEnvironmentVariable
は、 REG_EXPAND_SZ
値 %SystemRoot%\ system32
を C:\ Windows \ system32
の REG_SZ
値に変換します。
パス内の他の変数も失われます。 %myNewPath%
を使用して新しいものを追加しても、もう機能しません。
これが、この問題に対処するために使用するスクリプト「Set-PathVariable.ps1」です。
[CmdletBinding(SupportsShouldProcess=$true)]
param(
[parameter(Mandatory=$true)]
[string]$NewLocation)
Begin
{
#requires –runasadministrator
$regPath = "SYSTEM\CurrentControlSet\Control\Session Manager\Environment"
$hklm = [Microsoft.Win32.Registry]::LocalMachine
Function GetOldPath()
{
$regKey = $hklm.OpenSubKey($regPath, $FALSE)
$envpath = $regKey.GetValue("Path", "", [Microsoft.Win32.RegistryValueOptions]::DoNotExpandEnvironmentNames)
return $envPath
}
}
Process
{
# Win32API error codes
$ERROR_SUCCESS = 0
$ERROR_DUP_NAME = 34
$ERROR_INVALID_DATA = 13
$NewLocation = $NewLocation.Trim();
If ($NewLocation -eq "" -or $NewLocation -eq $null)
{
Exit $ERROR_INVALID_DATA
}
[string]$oldPath = GetOldPath
Write-Verbose "Old Path: $oldPath"
# Check whether the new location is already in the path
$parts = $oldPath.split(";")
If ($parts -contains $NewLocation)
{
Write-Warning "The new location is already in the path"
Exit $ERROR_DUP_NAME
}
# Build the new path, make sure we don't have double semicolons
$newPath = $oldPath + ";" + $NewLocation
$newPath = $newPath -replace ";;",""
if ($pscmdlet.ShouldProcess("%Path%", "Add $NewLocation")){
# Add to the current session
$env:path += ";$NewLocation"
# Save into registry
$regKey = $hklm.OpenSubKey($regPath, $True)
$regKey.SetValue("Path", $newPath, [Microsoft.Win32.RegistryValueKind]::ExpandString)
Write-Output "The operation completed successfully."
}
Exit $ERROR_SUCCESS
}
ブログ投稿で問題を詳しく説明します。
これにより、現在のセッションのパスが設定され、ユーザーに永続的に追加するように求められます。
function Set-Path {
param([string]$x)
$Env:Path+= ";" + $x
Write-Output $Env:Path
$write = Read-Host 'Set PATH permanently ? (yes|no)'
if ($write -eq "yes")
{
[Environment]::SetEnvironmentVariable("Path",$env:Path, [System.EnvironmentVariableTarget]::User)
Write-Output 'PATH updated'
}
}
この関数をデフォルトのプロファイル( Microsoft.PowerShell_profile.ps1```)に追加できます。通常、
%USERPROFILE%\ Documents \ WindowsPowerShell````にあります。
[@ Michael Kropat's][1]の回答に基づいて、既存の PATH
変数に新しいパスをプリペンドするパラメーターと、存在しないパスの追加を回避するためのチェックを追加しました。
function Add-EnvPath {
param(
[Parameter(Mandatory=$true)]
[string] $Path,
[ValidateSet('Machine', 'User', 'Session')]
[string] $Container = 'Session',
[Parameter(Mandatory=$False)]
[Switch] $Prepend
)
if (Test-Path -path "$Path") {
if ($Container -ne 'Session') {
$containerMapping = @{
Machine = [EnvironmentVariableTarget]::Machine
User = [EnvironmentVariableTarget]::User
}
$containerType = $containerMapping[$Container]
$persistedPaths = [Environment]::GetEnvironmentVariable('Path', $containerType) -split ';'
if ($persistedPaths -notcontains $Path) {
if ($Prepend) {
$persistedPaths = ,$Path + $persistedPaths | where { $_ }
[Environment]::SetEnvironmentVariable('Path', $persistedPaths -join ';', $containerType)
}
else {
$persistedPaths = $persistedPaths + $Path | where { $_ }
[Environment]::SetEnvironmentVariable('Path', $persistedPaths -join ';', $containerType)
}
}
}
$envPaths = $env:Path -split ';'
if ($envPaths -notcontains $Path) {
if ($Prepend) {
$envPaths = ,$Path + $envPaths | where { $_ }
$env:Path = $envPaths -join ';'
}
else {
$envPaths = $envPaths + $Path | where { $_ }
$env:Path = $envPaths -join ';'
}
}
}
}
[1]:https://stackoverflow.com/a/34844707/1509300「Michael Kropat」。
なので。 [ジョナサンリーダー。]https://stackoverflow.com/users/1689770/jonathan-leaders。) 言及した。 [ここに。]https://stackoverflow.com/a/28596275。) 'の環境変数を変更できるように、コマンド/スクリプト昇格を実行することが重要です。;machine'。;。, しかし、いくつかのコマンドを実行すると、diss'が昇格します。;コミュニティ拡張機能を使用する必要があります。, I'。;d変更して拡張したい。 [JeanT'。;s。]https://stackoverflow.com/users/1116269/jeant。) 。[答え。]https://stackoverflow.com/a/30694253。) ある意味で。, スクリプト自体が'であっても、マシン変数の変更も実行できます。;t run upleft:
function Set-Path ([string]$newPath, [bool]$permanent=$false, [bool]$forMachine=$false )
{
$Env:Path += ";$newPath"
$scope = if ($forMachine) { 'Machine' } else { 'User' }
if ($permanent)
{
$command = "[Environment]::SetEnvironmentVariable('PATH', $env:Path, $scope)"
Start-Process -FilePath powershell.exe -ArgumentList "-noprofile -command $Command" -Verb runas
}
}
ほとんどの回答はUACに対応していません。 これはUACの問題をカバーしています。
最初にPowerShell Community Extensionsをインストールします:http://chocolatey.org/を介して「choco install pscx」(シェル環境を再起動する必要がある場合があります)。
次に、pscxを有効にします。
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser #allows scripts to run from the interwebs, such as pcsx
次に、「Invoke-Elevated」を使用します。
Invoke-Elevated {Add-PathVariable $args[0] -Target Machine} -ArgumentList $MY_NEW_DIR
私の提案はこれです:
これをテストして、環境変数「Path」に「C:\ oracle \ x64 \ bin」を永続的に追加しましたが、これで問題なく動作します。
$ENV:PATH
最初の方法は、単に実行することです。
$ENV:PATH=”$ENV:PATH;c:\path\to\folder”
しかし、この変更は永続的なものではありません。 $ env:path
は、PowerShellターミナルを閉じて再度開くとすぐに、デフォルトで以前の状態に戻ります。 これは、ソースレベル(レジストリレベル)ではなく、セッションレベルで変更を適用したためです。 $ env:path
のグローバル値を表示するには、次のようにします。
Get-ItemProperty -Path ‘Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment’ -Name PATH
より具体的には:
(Get-ItemProperty -Path ‘Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment’ -Name PATH).path
これを変更するには、まず変更が必要な元のパスをキャプチャします。
$oldpath = (Get-ItemProperty -Path ‘Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment’ -Name PATH).path
次に、新しいパスの外観を定義します。 この場合、新しいフォルダを追加します。
$newpath = “$oldpath;c:\path\to\folder”
注: $ newpath
があなたがそれをどのように見たいかを見るようにしてください。 そうでない場合は、OSを損傷する可能性があります。
次に、新しい値を適用します。
Set-ItemProperty -Path ‘Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment’ -Name PATH -Value $newPath
次に、期待どおりに見えるように、最後に1つ確認します。
(Get-ItemProperty -Path ‘Registry::HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment’ -Name PATH).Path
これで、PowerShellターミナルを再起動(またはマシンを再起動)して、古い値に再びロールバックしないことを確認できます。
パスの順序がアルファベット順になるように変更される可能性があることに注意してください。行全体を確認してください。 簡単にするために、セミコロンを区切り文字として使用して、出力を行に分割できます。
($env:path).split(“;”)
SBFとMichael'sのコードを少し最適化して、よりコンパクトにしようとしました。
PowerShellのタイプの強制に依存しているため、文字列が自動的に列の値に変換されるため、検索辞書を定義しませんでした。
また、条件に基づいてリストに新しいパスを追加するブロックを引き出しました。これにより、作業は一度行われ、変数に保存されて再利用されます。
次に、「$ PathContainer」パラメーターに応じて、永続的またはセッションにのみ適用されます。
コードのブロックを、コマンドプロンプトから直接呼び出す関数またはps1ファイルに配置できます。 DevEnvAddPath.ps1を使用しました。
param(
[Parameter(Position=0,Mandatory=$true)][String]$PathChange,
[ValidateSet('Machine', 'User', 'Session')]
[Parameter(Position=1,Mandatory=$false)][String]$PathContainer='Session',
[Parameter(Position=2,Mandatory=$false)][Boolean]$PathPrepend=$false
)
[String]$ConstructedEnvPath = switch ($PathContainer) { "Session"{${env:Path};} default{[Environment]::GetEnvironmentVariable('Path', $containerType);} };
$PathPersisted = $ConstructedEnvPath -split ';';
if ($PathPersisted -notcontains $PathChange) {
$PathPersisted = $(switch ($PathPrepend) { $true{,$PathChange + $PathPersisted;} default{$PathPersisted + $PathChange;} }) | Where-Object { $_ };
$ConstructedEnvPath = $PathPersisted -join ";";
}
if ($PathContainer -ne 'Session')
{
# Save permanently to Machine, User
[Environment]::SetEnvironmentVariable("Path", $ConstructedEnvPath, $PathContainer);
}
# Update the current session
${env:Path} = $ConstructedEnvPath;
DevEnvRemovePath.ps1でも同様のことをしています。
param(
[Parameter(Position=0,Mandatory=$true)][String]$PathChange,
[ValidateSet('Machine', 'User', 'Session')]
[Parameter(Position=1,Mandatory=$false)][String]$PathContainer='Session'
)
[String]$ConstructedEnvPath = switch ($PathContainer) { "Session"{${env:Path};} default{[Environment]::GetEnvironmentVariable('Path', $containerType);} };
$PathPersisted = $ConstructedEnvPath -split ';';
if ($PathPersisted -contains $PathChange) {
$PathPersisted = $PathPersisted | Where-Object { $_ -ne $PathChange };
$ConstructedEnvPath = $PathPersisted -join ";";
}
if ($PathContainer -ne 'Session')
{
# Save permanently to Machine, User
[Environment]::SetEnvironmentVariable("Path", $ConstructedEnvPath, $PathContainer);
}
# Update the current session
${env:Path} = $ConstructedEnvPath;
これまでのところ、彼らは働いているようです。
PowerShell内では、次のように入力して環境変数ディレクトリに移動できます。
Set-Location Env:
これにより、Env:>に移動します。ディレクトリ。 このディレクトリ内から:
すべての環境変数を表示するには、次のように入力します。
Env:\> Get-ChildItem
特定の環境変数を表示するには、次のように入力します。
Env:\> $Env:<variable name>, e.g. $Env:Path
環境変数を設定するには、次のように入力します。
Env:\> $Env:<variable name> = "<new-value>", e.g. $Env:Path="C:\Users\"
環境変数を削除するには、次のように入力します。
Env:\> remove-item Env:<variable name>, e.g. remove-item Env:SECRET_KEY
詳細については、 [環境変数について][1] を参照してください。
[1]:https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_environment_variables?view = powershell-6。