Compartilhar via


Group-Object

Objetos de grupos que contêm o mesmo valor para as propriedades especificadas.

Sintaxe

Group-Object
     [-NoElement]
     [-AsHashTable]
     [-AsString]
     [-InputObject <PSObject>]
     [[-Property] <Object[]>]
     [-Culture <String>]
     [-CaseSensitive]
     [<CommonParameters>]

Description

O Group-Object cmdlet exibe objetos em grupos com base no valor de uma propriedade especificada. Group-Object Retorna uma tabela com uma linha para cada valor de propriedade e uma coluna que exibe o número de itens com esse valor.

Se você especificar mais de uma propriedade, Group-Object primeiro agrupe-as pelos valores da primeira propriedade e, em seguida, dentro de cada grupo de propriedades, ela será agrupada pelo valor da próxima propriedade.

A partir do PowerShell 7, Group-Object pode combinar os parâmetros CaseSensitive e AsHashtable para criar uma tabela de hash que diferencia maiúsculas de minúsculas. As chaves da tabela de hash usam comparações que diferenciam maiúsculas de minúsculas e geram um objeto System.Collections.Hashtable.

Exemplos

Exemplo 1: Agrupar arquivos por extensão

Este exemplo recursivamente obtém os arquivos e $PSHOME os agrupa por extensão de nome de arquivo. A saída é enviada para o Sort-Object cmdlet, que os classifica pelos arquivos de contagem encontrados para a extensão fornecida. O nome vazio representa diretórios.

Este exemplo usa o parâmetro NoElement para omitir os membros do grupo.

$files = Get-ChildItem -Path $PSHOME -Recurse
$files |
    Group-Object -Property extension -NoElement |
    Sort-Object -Property Count -Descending

Count Name
----- ----
  365 .xml
  231 .cdxml
  197
  169 .ps1xml
  142 .txt
  114 .psd1
   63 .psm1
   49 .xsd
   36 .dll
   15 .mfl
   15 .mof
...

Exemplo 2: Agrupar inteiros por pares e ímpares

Este exemplo mostra como usar blocos de script como o valor do parâmetro Property . Este comando exibe os inteiros de 1 a 20, agrupados por pares e ímpares.

1..20 | Group-Object -Property {$_ % 2}

Count Name                      Group
----- ----                      -----
   10 0                         {2, 4, 6, 8...}
   10 1                         {1, 3, 5, 7...}

Exemplo 3: Agrupar tabelas de hash por valor de chave

A partir do PowerShell 6, Group-Object dá suporte à classificação de entrada de tabela de hash por valores de chave. O exemplo a seguir agrupa uma matriz de tabelas de hash pelo valor da chave de cada tabela de weight hash.

Este exemplo usa o parâmetro NoElement para omitir os membros do grupo.

@(
    @{ name = 'a' ; weight = 7 }
    @{ name = 'b' ; weight = 1 }
    @{ name = 'c' ; weight = 3 }
    @{ name = 'd' ; weight = 7 }
) | Group-Object -Property weight -NoElement

Count Name
----- ----
    1 1
    1 3
    2 7

Exemplo 4: Agrupar eventos de log de eventos por EntryType

Este exemplo exibe as 1.000 entradas mais recentes no log de eventos do sistema, agrupadas por EntryType.

Na saída, a coluna Contagem representa o número de entradas em cada grupo. A coluna Nome representa os valores EventType que definem um grupo. A coluna Grupo representa os objetos em cada grupo.

Get-WinEvent -LogName System -MaxEvents 1000 | Group-Object -Property LevelDisplayName

Count Name          Group
----- ----          -----
  153 Error         {System.Diagnostics.Eventing.Reader.EventLogRecord, System.Diag...}
  722 Information   {System.Diagnostics.Eventing.Reader.EventLogRecord, System.Diag...}
  125 Warning       {System.Diagnostics.Eventing.Reader.EventLogRecord, System.Diag...}

Exemplo 5: Agrupar processos por classe de prioridade

Este exemplo demonstra o efeito do parâmetro NoElement . Esses comandos agrupam os processos no computador por classe de prioridade.

O primeiro comando usa o Get-Process cmdlet para obter os processos no computador e envia os objetos pelo pipeline. Group-Objectagrupa os objetos pelo valor da propriedade PriorityClass do processo.

O segundo exemplo usa o parâmetro NoElement para remover os membros do grupo da saída. O resultado é uma tabela com apenas o valor da propriedade Count e Name .

Os resultados são mostrados na seguinte saída de exemplo.

Get-Process | Group-Object -Property PriorityClass

Count Name         Group
----- ----         -----
   55 Normal       {System.Diagnostics.Process (AdtAgent), System.Diagnosti...
    1              {System.Diagnostics.Process (Idle)}
    3 High         {System.Diagnostics.Process (Newproc), System.Diagnostic...
    2 BelowNormal  {System.Diagnostics.Process (winperf),

Get-Process | Group-Object -Property PriorityClass -NoElement

Count Name
----- ----
   55 Normal
    1
    3 High
    2 BelowNormal

Exemplo 6: Agrupar processos por nome

O exemplo a seguir usa Group-Object para agrupar várias instâncias de processos em execução no computador local. Where-Object Exibe processos com mais de uma instância.

Get-Process | Group-Object -Property Name -NoElement | Where-Object {$_.Count -gt 1}

Count Name
----- ----
2     csrss
5     svchost
2     winlogon
2     wmiprvse

Exemplo 7: Agrupar objetos em uma tabela de hash

Este exemplo usa os parâmetros AsHashTable e AsString para retornar os grupos em uma tabela de hash, como uma coleção de pares chave-valor.

Na tabela de hash resultante, cada valor de propriedade é uma chave e os elementos de grupo são os valores. Como cada chave é uma propriedade do objeto de tabela de hash, você pode usar a notação de ponto para exibir os valores.

O primeiro comando obtém os Get cmdlets e Set na sessão, agrupa-os por verbo, retorna os grupos como uma tabela de hash e salva a $A tabela de hash na variável.

O segundo comando exibe a tabela de hash em $A. Há dois pares de chave-valor, um para os Get cmdlets e outro para os Set cmdlets.

O terceiro comando usa notação $A.Get de ponto para exibir os valores da chave Get em $A. Os valores são objeto CmdletInfo . O parâmetro AsString não converte os objetos nos grupos em cadeias de caracteres.

$A = Get-Command Get-*, Set-* -CommandType cmdlet |
     Group-Object -Property Verb -AsHashTable -AsString
$A

Name     Value
----     -----
Get      {Get-Acl, Get-Alias, Get-AppLockerFileInformation, Get-AppLockerPolicy...}
Set      {Set-Acl, Set-Alias, Set-AppBackgroundTaskResourcePolicy, Set-AppLockerPolicy...}

$A.Get

CommandType     Name                              Version    Source
-----------     ----                              -------    ------
Cmdlet          Get-Acl                           7.0.0.0    Microsoft.PowerShell.Security
Cmdlet          Get-Alias                         7.0.0.0    Microsoft.PowerShell.Utility
Cmdlet          Get-AppLockerFileInformation      2.0.0.0    AppLocker
Cmdlet          Get-AppLockerPolicy               2.0.0.0    AppLocker
...

Exemplo 8: Criar uma tabela de hash que diferencia maiúsculas de minúsculas

Este exemplo combina os parâmetros CaseSensitive e AsHashTable para criar uma tabela de hash que diferencia maiúsculas de minúsculas. Os arquivos no exemplo têm extensões de .txt e .TXT.

$hash = Get-ChildItem -Path C:\Files |
        Group-Object -Property Extension -CaseSensitive -AsHashTable
$hash

Name           Value
----           -----
.TXT           {C:\Files\File7.TXT, C:\Files\File8.TXT, C:\Files\File9.TXT}
.txt           {C:\Files\file1.txt, C:\Files\file2.txt, C:\Files\file3.txt}

A $hash variável armazena o objeto System.Collections.Hashtable. Get-ChildItem obtém os nomes de arquivo do C:\Files diretório e envia os objetos System.IO.FileInfo pelo pipeline. Group-Objectagrupa os objetos usando a extensão de valor de propriedade. Os parâmetros CaseSensitive e AsHashTable criam a tabela de hash e as chaves são agrupadas usando as chaves .txt que diferenciam maiúsculas de minúsculas e .TXT.

Parâmetros

-AsHashTable

Indica que esse cmdlet retorna o grupo como uma tabela de hash. As chaves da tabela de hash são os valores de propriedade pelos quais os objetos são agrupados. Os valores da tabela de hash são os objetos que têm o valor da propriedade.

Por si só, o parâmetro AsHashTable retorna cada tabela de hash na qual cada chave é uma instância do objeto agrupado. Quando usado com o parâmetro AsString , as chaves na tabela de hash são cadeias de caracteres.

A partir do PowerShell 7, para criar tabelas de hash que diferenciam maiúsculas de minúsculas, inclua CaseSensitive e AsHashtable em seu comando.

Tipo:SwitchParameter
Aliases:AHT
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-AsString

Indica que esse cmdlet converte as chaves da tabela de hash em cadeias de caracteres. Por padrão, as chaves de tabela de hash são instâncias de objeto agrupado. Esse parâmetro é válido somente quando usado com o parâmetro AsHashTable .

Tipo:SwitchParameter
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-CaseSensitive

Indica que esse cmdlet diferencia maiúsculas de minúsculas no agrupamento. Sem esse parâmetro, os valores de propriedade dos objetos em um grupo podem ter diferentes casos.

A partir do PowerShell 7, para criar tabelas de hash que diferenciam maiúsculas de minúsculas, inclua CaseSensitive e AsHashtable em seu comando.

Tipo:SwitchParameter
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Culture

Especifica a cultura a ser usada ao comparar cadeias de caracteres.

Tipo:String
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-InputObject

Especifica os objetos ao grupo. Insira uma variável que contém os objetos ou digite um comando ou uma expressão que obtém os objetos.

Quando você usa o parâmetro InputObject para enviar uma coleção de objetos para Group-Objecto , Group-Object o recebe um objeto que representa a coleção. Como resultado, ele cria um único grupo com esse objeto como seu membro.

Para agrupar os objetos em uma coleção, canalize os objetos para Group-Object.

Tipo:PSObject
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:True
Aceitar caracteres curinga:False

-NoElement

Indica que esse cmdlet omite os membros de um grupo dos resultados.

Tipo:SwitchParameter
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Property

Especifica as propriedades de agrupamento. Os objetos são organizados em grupos nomeados com base no valor das propriedades especificadas. Quando nenhuma propriedade é especificada, os objetos são agrupados por seu valor ou pela ToString() representação de seu valor. A saída é classificada em ordem crescente pelos nomes dos grupos.

O valor do parâmetro Property pode ser uma nova propriedade calculada. A propriedade calculada pode ser um bloco de script ou uma tabela de hash. Os pares de chave-valor válidos são:

  • Expressão - <string> ou <script block>

Para obter mais informações, consulte about_Calculated_Properties.

Tipo:Object[]
Cargo:0
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

Entradas

PSObject

Você pode canalizar qualquer objeto para esse cmdlet.

Saídas

GroupInfo

Por padrão, esse cmdlet retorna um objeto GroupInfo .

Hashtable

Quando você usa o parâmetro AsHashTable , esse cmdlet retorna um objeto Hashtable .

Observações

O PowerShell inclui os seguintes aliases para Group-Object:

  • Todas as plataformas:
    • group

Você pode usar o parâmetro GroupBy dos cmdlets de formatação, como Format-Table e Format-List, para agrupar objetos. Ao contrário Group-Objectdo , que cria uma única tabela com uma linha para cada valor de propriedade, os parâmetros GroupBy criam uma tabela para cada valor de propriedade com uma linha para cada item que tem o valor da propriedade.

Group-Object não exige que os objetos que estão sendo agrupados sejam do mesmo tipo do Microsoft .NET. Ao agrupar objetos de diferentes tipos .NET, Group-Object usa as seguintes regras:

  • Mesmos nomes e tipos de propriedade.

    Se os objetos tiverem uma propriedade com o nome especificado e os valores de propriedade tiverem o mesmo tipo .NET, os valores de propriedade serão agrupados pelas mesmas regras que seriam usadas para objetos do mesmo tipo.

  • Mesmos nomes de propriedade, tipos diferentes.

    Se os objetos tiverem uma propriedade com o nome especificado, mas os valores de propriedade tiverem um tipo .NET diferente em objetos diferentes, Group-Object usará o tipo .NET da primeira ocorrência da propriedade como o tipo .NET para esse grupo de propriedades. Quando um objeto tem uma propriedade com um tipo diferente, o valor da propriedade é convertido no tipo daquele grupo. Se a conversão de tipo falhar, o objeto não será incluído no grupo.

  • Propriedades ausentes.

    Objetos que não têm uma propriedade especificada não podem ser agrupados. Os objetos que não estão agrupados aparecem na saída final do objeto GroupInfo em um grupo chamado AutomationNull.Value.

A saída é classificada em ordem crescente pelos nomes dos grupos. Os itens pertencentes a cada grupo não são classificados. Eles são listados na ordem em que foram recebidos.