我有一个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执行此操作,还是我采取了错误的方法?
答案 0 :(得分:2)
Group-Object
是你的朋友。首先按TimeStamp排序,然后按组排序。它将在捕获的组中保持排序顺序,因此您可以读取第一个项目。
$data = "\\SomePath\LastLogon.csv"
Import-Csv $data | sort {[DateTime]$_.TimeStamp} -Desc | group UserName |%{ $_.Group[0] }