Share via


about_Environment_Provider

Nome do provedor

Ambiente

Unidades

Env:

Funcionalidades

DeveProcesso

Descrição breve

Fornece acesso a variáveis de ambiente do Windows.

Descrição detalhada

O provedor de Ambiente do PowerShell permite obter, adicionar, alterar, limpar e excluir variáveis e valores de ambiente no PowerShell.

As variáveis de ambiente são variáveis nomeadas dinamicamente que descrevem o ambiente no qual os programas são executados. O Windows e o PowerShell usam variáveis de ambiente para armazenar informações persistentes que afetam a execução do sistema e do processo. Ao contrário das variáveis do PowerShell, as variáveis de ambiente não estão sujeitas a restrições de escopo.

A unidade Environment é um namespace simples que contém as variáveis de ambiente específicas para a sessão do usuário atual. As variáveis de ambiente não têm itens filho.

O provedor de ambiente oferece suporte aos cmdlets a seguir, que são abordados neste artigo.

Tipos expostos por este provedor

Cada variável de ambiente é uma instância da classe System.Collections.DictionaryEntry . O nome da variável é a chave do dicionário. O valor da variável de ambiente é o valor do dicionário.

O provedor de ambiente expõe seu armazenamento de dados na Env: unidade. Para trabalhar com variáveis de ambiente, altere seu local para a Env: unidade (Set-Location Env:) ou trabalhe de outra unidade do PowerShell. Para fazer referência a uma variável de ambiente de outro local, use o nome da Env: unidade no caminho.

Set-Location Env:

Para retornar a uma unidade de sistema de arquivos, digite o nome da unidade. Por exemplo, digite:

Set-Location C:

Você também pode trabalhar com o provedor de Ambiente de qualquer outra unidade do PowerShell. Para fazer referência a uma variável de ambiente de outro local, use o nome Env: da unidade no caminho.

O provedor de ambiente também expõe variáveis de ambiente usando um prefixo de $env:variável de . O comando a seguir exibe o conteúdo da variável de ambiente ProgramFiles . O $env: prefixo da variável pode ser usado de qualquer unidade do PowerShell.

PS C:\> $env:ProgramFiles
C:\Program Files

Você também pode alterar o valor de uma variável de ambiente usando o prefixo da $env: variável. Quaisquer alterações feitas pertencem apenas à sessão atual do PowerShell enquanto ela estiver ativa.

Observação

O PowerShell usa aliases para permitir que você tenha uma maneira familiar de trabalhar com caminhos de provedor. Comandos como dir e ls agora são aliases para Get-ChildItem, cd é um alias para Set-Location. e pwd é um alias para Get-Location.

Obtendo variáveis de ambiente

Este comando lista todas as variáveis de ambiente na sessão atual.

Get-Item -Path Env:

Você pode usar esse comando de qualquer unidade do PowerShell.

O provedor de ambiente não tem contêineres, portanto, o comando acima tem o mesmo efeito quando usado com Get-ChildItemo .

Get-ChildItem -Path Env:

Obter uma variável de ambiente selecionada

Este comando obtém a WINDIR variável de ambiente.

Get-ChildItem -Path Env:windir

Você também pode usar o formato de prefixo de variável também.

$env:windir

Criar uma variável de ambiente

Esse comando cria a USERMODE variável de ambiente com um valor de "Non-Admin". O -Path valor do parâmetro cria o Env: novo item na unidade. A nova variável de ambiente só pode ser usada na sessão atual do PowerShell enquanto estiver ativa.

PS C:\> New-Item -Path Env: -Name USERMODE -Value Non-Admin

Alterando uma variável de ambiente

Renomear uma variável de ambiente

Esse comando usa o Rename-Item cmdlet para alterar o USERMODE nome da variável de ambiente que você criou para USERROLE. Não altere o nome de uma variável de ambiente que usa o sistema. Embora essas alterações afetem apenas a sessão atual, elas podem fazer com que o sistema ou um programa seja operado de forma incorreta.

Rename-Item -Path Env:USERMODE -NewName USERROLE

Alterar uma variável de ambiente

Esse comando usa o Set-Item cmdlet para alterar o valor da variável de USERROLE ambiente para "Administrador".

Set-Item -Path Env:USERROLE -Value Administrator

Copiar uma variável de ambiente

Este comando copia o USERROLE valor da variável de ambiente para a USERROLE2 variável de ambiente.

Copy-Item -Path Env:USERROLE -Destination Env:USERROLE2

Remover uma variável de ambiente

Esse comando exclui a USERROLE2 variável de ambiente da sessão atual.

Remove-Item -Path Env:USERROLE2

Remover uma variável de ambiente com Clear-Item

Esse comando exclui a USERROLE variável de ambiente limpando seu valor.

Clear-Item -Path Env:USERROLE

Usando o pipeline

Os cmdlets do provedor aceitam entrada de pipeline. Você pode usar o pipeline para simplificar a tarefa enviando dados do provedor de um cmdlet para outro cmdlet do provedor. Para ler mais sobre como usar o pipeline com cmdlets de provedor, consulte as referências de cmdlet fornecidas ao longo deste artigo.

Obtendo ajuda

A partir do Windows PowerShell 3.0, você pode obter tópicos da Ajuda personalizados para cmdlets do provedor que explicam como esses cmdlets se comportam em uma unidade de sistema de arquivos.

Para obter os tópicos de ajuda personalizados para a unidade do sistema de arquivos, execute um comando Get-Help em uma unidade do sistema de arquivos ou use o -Path parâmetro Get-Help para especificar uma unidade do sistema de arquivos.

Get-Help Get-ChildItem
Get-Help Get-ChildItem -Path env:

Confira também