Windows Powershell排序和分组管道结果

使用Sort-Object和Group-Object可以对管道结果进行分组。
其实每条命令执行后的结果已经排过序了。例如通过ls 查看文件列表,默认会根据Name属性进行排序,但是你可以通过指定属性进行排序例如:

PS C:Powershell> ls | Sort-Object Length
Mode     LastWriteTime Length Name
----     ------------- ------ ----
-a--- 2011/11/28   15:30   63 ping.bat
-a--- 2011/12/2   18:47  140 test.ps1
-a--- 2011/11/28   16:42  170 test.vbs
-a--- 2011/11/28   11:12  186 LogoTestConfig.xml
-a--- 2011/11/23   17:37  242 test.txt
-a--- 2011/11/25   11:20  556 employee.xml

这样默认会根据length进行升序排序,如果要降序排列,可是使用Descending选项。

PS C:Powershell> ls | Sort-Object Length -Descending
Mode     LastWriteTime Length Name
----     ------------- ------ ----
-a--- 2011/11/24   17:44 735892 Powershell_Cmdlets.html
-a--- 2011/11/24   18:30 67580 a.html
-a--- 2011/11/24   20:04 26384 a.txt
-a--- 2011/11/29   19:23 21466 function.ps1
-a--- 2011/11/24   20:26 12060 alias
-a--- 2011/11/24   17:37  7420 name.html

给对象和哈希表进行排序

如果要完成主要关键字降序,次要关键字升序的排序,可能首先想到的是:

PS C:Powershell> Dir | Sort-Object Length, Name -descending, -ascending
Sort-Object : 找不到接受实际参数“System.Object[]”的位置形式参数。
所在位置 行:1 字符: 18
+ Dir | Sort-Object <<<< Length, Name -descending, -ascending
  + CategoryInfo     : InvalidArgument: (:) [Sort-Object], ParameterBin
  dingException
  + FullyQualifiedErrorId : PositionalParameterNotFound,Microsoft.PowerShell
  .Commands.SortObjectCommand

但是上面的方法行不通,可是这样操作:

PS C:Powershell> Dir | Sort-Object @{expression="Length";Descending=$true},@{ex
pression="Name";Ascending=$true}

  目录: C:Powershell

Mode     LastWriteTime Length Name
----     ------------- ------ ----
-a--- 2011/11/24   17:44 735892 Powershell_Cmdlets.html
-a--- 2011/11/24   18:30 67580 a.html
-a--- 2011/11/24   20:04 26384 a.txt
-a--- 2011/11/29   19:23 21466 function.ps1
-a--- 2011/11/24   20:26 12060 alias
-a--- 2011/11/24   17:37  7420 name.html
-a--- 2011/12/14   11:22  3460 ls.html
-a--- 2011/11/30   16:04  2556 psdrive.html
-a--- 2011/11/25   11:20  556 employee.xml
-a--- 2011/11/23   17:37  242 test.txt
-a--- 2011/11/28   11:12  186 LogoTestConfig.xml
-a--- 2011/11/28   16:42  170 test.vbs
-a--- 2011/12/2   18:47  140 test.ps1

对数据进行分组

如果想查看当前关闭和开启的所有服务,并且通过状态进行分组。可是使用:

PS C:Powershell> Get-Service | Group-Object Status
Count Name  Group
----- ----  -----
  87 Running {System.ServiceProcess.ServiceController, System.ServiceProcess.S
       erviceController, System.ServiceProcess.ServiceController, System
       .ServiceProcess.ServiceController...}
  88 Stopped {System.ServiceProcess.ServiceController, System.ServiceProcess.S
       erviceController, System.ServiceProcess.ServiceController, System
       .ServiceProcess.ServiceController...}

再举一例,把当前目录的文件以扩展名进行分组

PS C:Powershell> ls | Group-Object Extension
Count Name Group
----- ---- -----
  2    {ABC, alias}
  5 .html {a.html, ls.html, name.html, Powershell_Cmdlets.html...}
  2 .txt {a.txt, test.txt}
  2 .xml {employee.xml, LogoTestConfig.xml}
  2 .ps1 {function.ps1, test.ps1}
  1 .bat {ping.bat}
  1 .vbs {test.vbs}

使用表达式分组

如果要查看当前目录的文件,根据文件的大小是否大于1kb分组。

PS C:Powershell> ls | Group-Object {$_.Length -gt 1kb}

Count Name           Group
----- ----           -----
  7 False           {ABC, employee.xml, LogoTestConfig.xml, ping...
  8 True           {a.html, a.txt, alias, function.ps1...}

如果按照文件名的首字母分组

PS C:Powershell> ls | Group-Object {$_.name.SubString(0,1).toUpper()}
Count Name Group
----- ---- -----
  3 A  {a.html, a.txt, alias}
  1 E  {employee.xml}
  1 F  {function.ps1}
  2 L  {LogoTestConfig.xml, ls.html}
  1 N  {name.html}
  3 P  {ping.bat, Powershell_Cmdlets.html, psdrive.html}
  3 T  {test.ps1, test.txt, test.vbs}

根据当前应用程序的发布者分组

PS C:Powershell> Get-Process | Group-Object Company -NoElement

Count Name
----- ----
  2 Adobe Systems Incorpor...
  52
  2 微软
  22 Microsoft Corporation
  1 Adobe Systems, Inc.
  1 Microsoft (R) Corporation
  1
  1 NVIDIA Corporation

使用格式化命令分组

Group-Object并不是唯一可以完成分组功能的命令,事实上格式化命令例如Format-Object支持一个GroupBy的参数,也可以完成分组。

PS C:Powershell> Dir | Sort-Object Extension, Name | Format-Table -groupBy Extension

  目录: C:Powershell

Mode        LastWriteTime   Length Name
----        -------------   ------ ----
-a---    2011/11/24   20:26   12060 alias

  目录: C:Powershell

Mode        LastWriteTime   Length Name
----        -------------   ------ ----
-a---    2011/11/28   15:30     63 ping.bat

  目录: C:Powershell

Mode        LastWriteTime   Length Name
----        -------------   ------ ----
-a---    2011/11/24   18:30   67580 a.html
-a---    2011/12/14   11:22    3460 ls.html
-a---    2011/11/24   17:37    7420 name.html
-a---    2011/11/24   17:44   735892 Powershell_Cmdlets.html
-a---    2011/11/30   16:04    2556 psdrive.html
(0)

相关推荐

  • Windows Powershell分析和比较管道结果

    使用Measure-Object和Compare-Object可以统计和对比管道结果.Measure-Object允许指定待统计对象的属性.Compare-Object可以对比对象前后的快照. 统计和计算 使用Measure-Object可以对对象的属性求最小值.最大值.平均值.和.例如要查看当前目录文件占用空间的情况. PS C:Powershell> ls | measure length Count : 19 Average : Sum : Maximum : Minimum : Prop

  • Windows Powershell 管道和重定向

    管道 把上一条命令的输出作为下一条命令的输入. PowerShell管道 例如通过ls获取当前目录的所有文件信息,然后通过Sort -Descending对文件信息按照Name降序排列,最后将排序好的文件的Name和Mode格式化成Table输出. PS C:\PStest> ls | sort -Descending Name | Format-Table Name,Mode Name Mode ---- ---- d.txt -a--- c.txt -a--- b.txt -a--- ABC

  • PowerShell管道入门必看篇(管道例子大全)

    PowerShell的一个重中之重的功能就是管道(pipeline),本文从浅入深,一步一步详解管道的使用方法和例子,来看看有没有你所不知道的吧,如果全知道,恭喜你已经很厉害啦--适用于所有PowerShell应用小白与技术老鸟.另外欢迎各位技术大牛来补充讨论学习~ 1. 管道(pipeline)是什么 在Shell中一个重要的基本概念就是管道(pipeline),即在一组命令中,输出的命令结果成为下一个命令的输入参数.管道的概念与真实生活中的生产线比较相似:在不同的生产环节进行连续的再加工,如

  • Windows Powershell导出管道结果

    可以将管道的结果转换成文本输出,默认是Out-Default.可以通过Get-Command -verb out查看Powershell都有哪些输出的命令. 复制代码 代码如下: PS C:PowerShell> get-command -Verb out CommandType Name         Definition ----------- ----         ---------- Cmdlet      Out-Default  Out-Default [-InputObjec

  • PowerShell函数中接收管道参数实例

    本文介绍在自定义PowerShell函数时,如何设置函数通过管道(Pipeline)接收输入参数. 先看一个例子,用管道作为输入参数的函数: 复制代码 代码如下: function Test-Pipeline {     param(         [Parameter(ValueFromPipeline=$true)]         $InputObject     )     process     {         "Working with $InputObject"  

  • PowerShell中使用Filter来创建管道输入函数

    本文介绍在自定义PowerShell函数时,不使用Function而使用Filter.Filter可以快速的创建一个管道输入函数,Filter就相当于只有一个Process块的Function. Filter关键词可以代替Function关键词来创建函数.但Filter创建的函数,只能是接收管道输入参数的参数,并且是接收块结构数据的输入.所以在Filter定义的函数里面,你都看不到接收输入参数. 在Filter定义的函数中,使用$_变量,来遍历所有的输入对象. 复制代码 代码如下: Filter

  • PowerShell实现按条件终止管道的方法

    有时你可能想在管道运行在某个特定的条件下,终止管道.今天来演示一个比较新颖的方式,它适用于PowerShell 2.0或着更高版本.先看代码: filter Stop-Pipeline { param ( [scriptblock] $condition = {$true} ) if (& $condition) { continue } $_ } do { Get-ChildItem c:\Windows -Recurse -ErrorAction SilentlyContinue | Sto

  • Windows Powershell使用管道

    管道并不是什么新事物,以前的Cmd控制台也有重定向的命令,例如Dir | More可以将结果分屏显示. 传统的Cmd管道是基于文本的,但是Powershell是基于对象. PS> ls | Sort-Object -Descending Name | Select-Object Name,Length,LastWriteTime | ConvertTo-Html | Out-File ls.html PS> Get-Content .ls.html Name Length LastWriteT

  • PowerShell中终止管道的方法

    如果你能够提前知道你想从管道中获取元素的个数,可以使用Select-Object来终止流处理命令的的管道,这会节省很多时间. 下面的例子会从Windows文件夹下搜寻 explorer.exe示例,因为Select-Object语句可以在管道找到结果的那一瞬终止管道.否则,Get-ChildItem会递归的遍历所有子目录然后匹配出你想要的结果. 复制代码 代码如下: #requires -Version 3 Get-ChildItem -Path c:\Windows -Recurse -Fil

  • PowerShell入门教程之PowerShell管道介绍

    管道对于Shell来说是个化腐朽为神奇的东西,它极大地提高了在命令行上编程的能力.深入理解并熟练使用管道是PowerShell高手之路的必经阶段.没有管道,我们就不得不通过许多的变量来保存中间结果,虽然这是脚本和其他编译型语言的惯用伎俩,但对于战斗在命令行上的Shell而言,就是一件非常痛苦的事情. 管道模型 顾名思义,管道就是用管子将事物连接起来构成通道.从表面上看,管道是一串由管道符号(|)连接起来的一些命令.从功能来看,管道就像流水线,将上一个处理的结果,传送给下一个处理作为输入.由管道连

  • Windows Powershell过滤管道结果

    如果要过滤对象可以使用Where-Object:如果要过滤对象的属性,可以使用Select-Object:如果要自定义个性化的过滤效果可以使用ForEach-Object.最后如果想过滤重复的结果,可是使用Get-Uinque. 筛选管道结果中的对象 如果你只对管道结果的特定对象感兴趣,可是使用Where-Object对每个结果进行严格筛选,一旦满足你的标准才会保留,不满足标准的就会自动丢弃.例如你通过Get-service查看运行在机器上的当前服务,但是可能只关心哪些正在运行的服务,这时就可是

随机推荐