Get-Unique
Retorna itens exclusivos de uma lista classificada.
Sintaxe
Get-Unique
[-InputObject <PSObject>]
[-AsString]
[-CaseInsensitive]
[<CommonParameters>]
Get-Unique
[-InputObject <PSObject>]
[-OnType]
[-CaseInsensitive]
[<CommonParameters>]
Description
O cmdlet Get-Unique
compara cada item de uma lista classificada com o próximo item, elimina duplicatas e retorna apenas uma instância de cada item. A lista deve ser classificada para que o cmdlet funcione corretamente.
Por padrão, Get-Unique
diferencia maiúsculas de minúsculas. Como resultado, as cadeias de caracteres que diferem apenas na caixa de caracteres são consideradas exclusivas.
Exemplos
Exemplo 1: Obter palavras exclusivas em um arquivo de texto
Esses comandos localizam o número de palavras exclusivas em um arquivo de texto.
$A = $( foreach ($line in Get-Content C:\Test1\File1.txt) {
$line.tolower().split(" ")
}) | Sort-Object | Get-Unique
$A.count
O primeiro comando obtém o conteúdo do arquivo File.txt
. Ele converte cada linha de texto em letras minúsculas e, em seguida, divide cada palavra em uma linha separada no espaço (" "
). Em seguida, ele classifica a lista resultante em ordem alfabética (o padrão) e usa o cmdlet Get-Unique
para eliminar palavras duplicadas. Os resultados são armazenados na variável $A
.
O segundo comando usa a propriedade Count da coleção de cadeias de caracteres em $A
para determinar quantos itens estão em $A
.
Exemplo 2: Obter inteiros exclusivos em uma matriz
Este comando localiza os membros exclusivos do conjunto de inteiros.
1,1,1,1,12,23,4,5,4643,5,3,3,3,3,3,3,3 | Sort-Object | Get-Unique
1
3
4
5
12
23
4643
O primeiro comando usa uma matriz de inteiros digitados na linha de comando, canaliza-os para o cmdlet Sort-Object
a ser classificado e, em seguida, canaliza-os para Get-Unique
, o que elimina entradas duplicadas.
Exemplo 3: Obter tipos de objeto exclusivos em um diretório
Este comando usa o cmdlet Get-ChildItem
para recuperar o conteúdo do diretório local, que inclui arquivos e diretórios.
Get-ChildItem | Sort-Object {$_.GetType()} | Get-Unique -OnType
O operador de pipeline (|
) envia os resultados para o cmdlet Sort-Object
. A instrução $_.GetType()
aplica o método GetType a cada arquivo ou diretório. Em seguida, Sort-Object
classifica os itens por tipo. Outro operador de pipeline envia os resultados para Get-Unique
. O parâmetro OnType direciona Get-Unique
para retornar apenas um objeto de cada tipo.
Exemplo 4: Obter processos exclusivos
Este comando obtém os nomes dos processos em execução no computador com duplicatas eliminadas.
Get-Process | Sort-Object | Select-Object processname | Get-Unique -AsString
O comando Get-Process
obtém todos os processos no computador. O operador de pipeline (|
) passa o resultado para Sort-Object
, que, por padrão, classifica os processos alfabeticamente por ProcessName. Os resultados são canalizados para o cmdlet Select-Object
, que seleciona apenas os valores da propriedade ProcessName de cada objeto. Os resultados são então canalizados para Get-Unique
eliminar duplicatas.
O parâmetro AsString diz a Get-Unique
para tratar os valores ProcessName como cadeias de caracteres.
Sem esse parâmetro, Get-Unique
trata os valores ProcessName como objetos e retorna apenas uma instância do objeto, ou seja, o primeiro nome do processo na lista.
Exemplo 5: Use comparações que diferenciam maiúsculas de minúsculas para obter cadeias de caracteres exclusivas
Este exemplo usa comparações que não diferenciam maiúsculas de minúsculas para obter cadeias de caracteres exclusivas de uma matriz de cadeias de caracteres.
"aa", "Aa", "Bb", "bb", "aa" | Sort-Object -CaseSensitive | Get-Unique
aa
Aa
bb
Bb
Exemplo 6: Use comparações que não diferenciam maiúsculas de minúsculas para obter cadeias de caracteres exclusivas
Este exemplo usa comparações que não diferenciam maiúsculas de minúsculas para obter cadeias de caracteres exclusivas de uma matriz de cadeias de caracteres.
"aa", "Aa", "Bb", "bb", "aa" | Sort-Object | Get-Unique -CaseInsensitive
aa
Bb
Parâmetros
-AsString
Indica que esse cmdlet usa os dados como uma cadeia de caracteres. Sem esse parâmetro, os dados são tratados como um objeto, portanto, quando você envia uma coleção de objetos do mesmo tipo para Get-Unique
, como uma coleção de arquivos, ele retorna apenas um (o primeiro). Você pode usar esse parâmetro para localizar os valores exclusivos das propriedades do objeto, como os nomes de arquivo.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-CaseInsensitive
Por padrão, Get-Unique
diferencia maiúsculas de minúsculas. Quando você usa esse parâmetro, o cmdlet usa comparações que não diferenciam maiúsculas de minúsculas.
Esse parâmetro foi adicionado no PowerShell 7.4.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | False |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
-InputObject
Especifica a entrada para Get-Unique
. Insira uma variável que contenha os objetos ou digite um comando ou expressão que obtenha os objetos.
Este cmdlet trata a entrada enviada usando InputObject como uma coleção. Ele não enumera itens individuais na coleção. Como a coleção é um único item, a entrada enviada usando InputObject é sempre retornada inalterada.
Tipo: | PSObject |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | True |
Aceitar carateres universais: | False |
-OnType
Indica que esse cmdlet retorna apenas um objeto de cada tipo.
Tipo: | SwitchParameter |
Position: | Named |
Default value: | None |
Necessário: | False |
Aceitar entrada de pipeline: | False |
Aceitar carateres universais: | False |
Entradas
Você pode canalizar qualquer tipo de objeto para este cmdlet.
Saídas
Este cmdlet retorna seus objetos de entrada sem duplicatas.
Notas
O PowerShell inclui os seguintes aliases para Get-Unique
:
- Todas as plataformas:
gu
Para obter mais informações, consulte about_Aliases.
Para classificar uma lista, use Sort-Object
. Você também pode usar o parâmetro Unique de Sort-Object
para localizar os itens exclusivos em uma lista.