如何使用PowerShell解析csv文件以获取特定结果

时间:2012-08-20 15:55:09

标签: powershell

我有一个CSV文件,其中包含用户的登录数据,并希望使用PowerShell解析数据以查找每个用户的上次登录。

数据格式为:

TimeStamp                  UserName                           
---------                  --------                           
10/14/2011 12:53:12 PM     Smith                      
10/14/2011 12:54:07 PM     Jones                      
10/14/2011 12:59:45 PM     Green                      
10/14/2011 1:10:43 PM      Brown                      
8/20/2012 6:20:11 PM       Jones                     
8/20/2012 6:20:36 PM       Brown                     
8/20/2012 6:33:04 PM       Smith                      
8/20/2012 6:35:45 PM       Brown                  
8/20/2012 6:45:05 PM       Jones                  
8/20/2012 6:45:45 PM       Smith 

所需的输出是:

UserName                   TimeStamp                          
--------                   ---------                           
Brown                      8/20/2012 6:45:45 PM
Green                      10/14/2011 12:59:45 PM
Jones                      8/20/2012 6:45:05 PM
Smith                      8/20/2012 6:45:45 PM

我可以逐行,嵌套循环,解决方案来做到这一点,但这似乎是用PowerShell接近它的一种不好的方法。

我可以读取csv数据并按UserName和TimeStamp对其进行排序:

$data = "\\SomePath\LastLogon.csv"
$list = Import-Csv $data |Sort @{expression="UserName";Ascending=$true},@{expression="TimeStamp";Descending=$true}
$list

但我现在仍然坚持如何过滤最后一次登录。有没有一种简单的方法可以使用PowerShell执行此操作,还是我采取了错误的方法?

1 个答案:

答案 0 :(得分:2)

Group-Object是你的朋友。首先按TimeStamp排序,然后按组排序。它将在捕获的组中保持排序顺序,因此您可以读取第一个项目。

$data = "\\SomePath\LastLogon.csv"
Import-Csv $data | sort {[DateTime]$_.TimeStamp} -Desc | group UserName |%{ $_.Group[0] }