0

我有一个包含用户登录数据的 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 做到这一点,还是我采取了错误的方法?

4

1 回答 1

2

Group-Object是你的朋友。首先按时间戳排序,然后分组。它将保持捕获组内的排序顺序,因此您只需读取第一项即可。

$data = "\\SomePath\LastLogon.csv"
Import-Csv $data | sort {[DateTime]$_.TimeStamp} -Desc | group UserName |%{ $_.Group[0] }
于 2012-08-20T16:52:44.333 回答