使用Robocopy获取文件列表

时间:2015-02-05 21:01:17

标签: powershell robocopy cmdlets

我正在尝试查看使用Robocopy的解决方案是否比使用Get-ChildItem获取给定文件夹(以及子文件夹...)中的文件列表更快。

在我的代码中,我使用Get-ChildItem cmdlet获取特定文件夹中所有文件的列表,以便遍历每个文件:

$files = Get-ChildItem "C:\aaa" -Recurse | where {! $_.PIsContainer} # ! because I don't want to list folders
foreach ($file in $files){
...
}

现在,我有robocopy命令来获取所有文件的列表,但是,robocopy的输出是一个字符串。

[string]$result = robocopy "C:\aaa" NULL /l /s /ndl /xx /nc /ns /njh /njs /fp

那么,我如何使用robocopy命令的输出循环每个文件(类似于Get-ChildItem所做的那样?

3 个答案:

答案 0 :(得分:4)

如果你只是想找到一种更快的方法来获取文件列表,那么传统的dir命令就会这样做:

$files = cmd /c dir c:\aaa /b /s /a-d
foreach ($file in $files){
...
}

编辑:一些比较性能测试 -

(measure-command {gci -r |? {-not $_.psiscontainer } }).TotalMilliseconds
(measure-command {gci -r -file}).TotalMilliseconds
(measure-command {(robocopy . NULL /l /s /ndl /xx /nc /ns /njh /njs /fp) }).TotalMilliseconds
(measure-command {cmd /c dir /b /s /a-d }).TotalMilliseconds

627.5434
417.8881
299.9069
86.9364

测试目录在420个子目录中有6812个文件。

答案 1 :(得分:1)

$array = $files -split '\r?\n'

我假设$files是由换行符分隔的文本。这将按换行符拆分字符串并分配给$array

答案 2 :(得分:1)

看起来Robocopy输出受到空白区域的影响。这有效:

(robocopy . NULL /l /s /ndl /xx /nc /ns /njh /njs /fp) | % {gci $_.trim()}

是否更快取决于您如何过滤文件。如果您的PS版支持-file cmdlet gci(因此将过滤交给文件系统提供程序),则PS速度最快。使用Where-Object大致加倍,而Robocopy介于两者之间(对于240个文件的例子):

measure-command {gci -r -file}


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 24
Ticks             : 245746
TotalDays         : 2.84428240740741E-07
TotalHours        : 6.82627777777778E-06
TotalMinutes      : 0.000409576666666667
TotalSeconds      : 0.0245746
TotalMilliseconds : 24.5746



measure-command  {gci -r | ? {$_.PSIsContainer -eq $false}}


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 48
Ticks             : 480647
TotalDays         : 5.56304398148148E-07
TotalHours        : 1.33513055555556E-05
TotalMinutes      : 0.000801078333333333
TotalSeconds      : 0.0480647
TotalMilliseconds : 48.0647



measure-command {(robocopy . NULL /l /s /ndl /xx /nc /ns /njh /njs /fp)}


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 36
Ticks             : 365689
TotalDays         : 4.23251157407407E-07
TotalHours        : 1.01580277777778E-05
TotalMinutes      : 0.000609481666666667
TotalSeconds      : 0.0365689
TotalMilliseconds : 36.5689