about_Environment_Provider

Nome do fornecedor

Environment

Unidades

Env:

Capacidades

DeveProcessar

Breve descrição

Fornece acesso às 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 seus 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 de ambiente é 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 em 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 do sistema de arquivos, digite o nome da unidade. Por exemplo, escreva:

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 variável de $env:. 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 referem-se apenas à sessão atual do PowerShell enquanto ela estiver ativa.

Nota

O PowerShell usa aliases para permitir 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.

Obter 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-ChildItem.

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 variável.

$env:windir

Criar uma variável de ambiente

Este comando cria a USERMODE variável de ambiente com um valor de "Non-Admin". O -Path valor do parâmetro cria o novo item na Env: 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

Alterar uma variável de ambiente

Renomear uma variável de ambiente

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

Rename-Item -Path Env:USERMODE -NewName USERROLE

Alterar uma variável de ambiente

Este comando usa o Set-Item cmdlet para alterar o USERROLE valor da variável de 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

Este 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

Este 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.

Obter ajuda

A partir do Windows PowerShell 3.0, você pode obter tópicos de ajuda personalizados para cmdlets de provedor que explicam como esses cmdlets se comportam em uma unidade do 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:

Consulte também