Partilhar via


Ordenação de objetos

Podemos organizar os dados exibidos para facilitar a digitalização usando o Sort-Object cmdlet. Sort-Object toma o nome de uma ou mais propriedades para ordenar e devolve dados ordenados pelos valores dessas propriedades.

Ordenação básica

Considere o problema de listar subdiretórios e ficheiros no diretório atual. Se quisermos ordenar por LastWriteTime e depois por Nome, podemos fazê-lo escrevendo:

Get-ChildItem |
    Sort-Object -Property LastWriteTime, Name |
    Format-Table -Property LastWriteTime, Name
LastWriteTime          Name
-------------          ----
11/6/2017 10:10:11 AM  .localization-config
11/6/2017 10:10:11 AM  .openpublishing.build.ps1
11/6/2017 10:10:11 AM  appveyor.yml
11/6/2017 10:10:11 AM  LICENSE
11/6/2017 10:10:11 AM  LICENSE-CODE
11/6/2017 10:10:11 AM  ThirdPartyNotices
11/6/2017 10:10:15 AM  tests
6/6/2018 7:58:59 PM    CONTRIBUTING.md
6/6/2018 7:58:59 PM    README.md
...

Também podes ordenar os objetos em ordem inversa especificando o parâmetro Descendente[switch] .

Get-ChildItem |
  Sort-Object -Property LastWriteTime, Name -Descending |
  Format-Table -Property LastWriteTime, Name
LastWriteTime          Name
-------------          ----
12/1/2018 10:13:50 PM  reference
12/1/2018 10:13:50 PM  dsc
...
6/6/2018 7:58:59 PM    README.md
6/6/2018 7:58:59 PM    CONTRIBUTING.md
11/6/2017 10:10:15 AM  tests
11/6/2017 10:10:11 AM  ThirdPartyNotices
11/6/2017 10:10:11 AM  LICENSE-CODE
11/6/2017 10:10:11 AM  LICENSE
11/6/2017 10:10:11 AM  appveyor.yml
11/6/2017 10:10:11 AM  .openpublishing.build.ps1
11/6/2017 10:10:11 AM  .localization-config

Utilização de tabelas de hash

Podes ordenar diferentes propriedades em diferentes ordens usando tabelas hash num array. Cada tabela de hash usa uma chave Expression para especificar o nome da propriedade como string e uma chave Ascendente ou Descendente para especificar a ordem por $true ou $false. A tecla Expressão é obrigatória. A tecla Ascendente ou Descendente é opcional.

O exemplo seguinte ordena os objetos na ordem decrescente LastWriteTime e na ordem crescente do Nome .

Get-ChildItem |
  Sort-Object -Property @{ Expression = 'LastWriteTime'; Descending = $true },
                        @{ Expression = 'Name'; Ascending = $true } |
  Format-Table -Property LastWriteTime, Name
LastWriteTime          Name
-------------          ----
12/1/2018 10:13:50 PM  dsc
12/1/2018 10:13:50 PM  reference
11/29/2018 6:56:01 PM  .openpublishing.redirection.json
11/29/2018 6:56:01 PM  gallery
11/24/2018 10:33:22 AM developer
11/20/2018 7:22:19 PM  .markdownlint.json
...

Também podes definir um bloco de script para a tecla Expressão . Ao executar o Sort-Object cmdlet, o bloco de script é executado e o resultado é usado para ordenação.

O exemplo seguinte ordena os objetos por ordem decrescente pelo intervalo de tempo entre CreationTime e LastWriteTime.

Get-ChildItem |
    Sort-Object -Property @{ Exp = { $_.LastWriteTime - $_.CreationTime }; Desc = $true } |
    Format-Table -Property LastWriteTime, CreationTime
LastWriteTime          CreationTime
-------------          ------------
12/1/2018 10:13:50 PM  11/6/2017 10:10:11 AM
12/1/2018 10:13:50 PM  11/6/2017 10:10:11 AM
11/7/2018 6:52:24 PM   11/6/2017 10:10:11 AM
11/7/2018 6:52:24 PM   11/6/2017 10:10:15 AM
11/3/2018 9:58:17 AM   11/6/2017 10:10:11 AM
10/26/2018 4:50:21 PM  11/6/2017 10:10:11 AM
11/17/2018 1:10:57 PM  11/29/2017 5:48:30 PM
11/12/2018 6:29:53 PM  12/7/2017 7:57:07 PM
...

Sugestões

Pode omitir o nome do parâmetro Propriedade da seguinte forma:

Sort-Object LastWriteTime, Name

Além disso, pode referir-se a Sort-Object pelo seu pseudónimo incorporado, sort:

sort LastWriteTime, Name

As chaves nas tabelas de hash para ordenação podem ser abreviadas da seguinte forma:

Sort-Object @{ e = 'LastWriteTime'; d = $true }, @{ e = 'Name'; a = $true }

Neste exemplo, o e representa Expressão, o d representa Descendente, e o a representa Ascendente.

Para melhorar a legibilidade, pode colocar as tabelas de hash numa variável separada:

$order = @(
  @{ Expression = 'LastWriteTime'; Descending = $true }
  @{ Expression = 'Name'; Ascending = $true }
)

Get-ChildItem |
    Sort-Object $order |
    Format-Table LastWriteTime, Name