使用PowerShell循环浏览目录中的文件

如何更改以下代码以查看目录中的所有.log文件,而不仅仅是一个文件?


我需要遍历所有文件并删除所有不包含“ step4”或“ step9”的行。当前,这将创建一个新文件,但是我不确定如何在for each此处使用循环(新手)。


实际文件的命名如下:2013 09 03 00_01_29.log。我希望输出文件覆盖它们,或者具有相同的名称,并附加“ out”。


$In = "C:\Users\gerhardl\Documents\My Received Files\Test_In.log"

$Out = "C:\Users\gerhardl\Documents\My Received Files\Test_Out.log"

$Files = "C:\Users\gerhardl\Documents\My Received Files\"


Get-Content $In | Where-Object {$_ -match 'step4' -or $_ -match 'step9'} | `

Set-Content $Out


千万里不及你
浏览 982回答 3
3回答

慕村225694

试试看:Get-ChildItem "C:\Users\gerhardl\Documents\My Received Files" -Filter *.log | Foreach-Object {    $content = Get-Content $_.FullName    #filter and save content to the original file    $content | Where-Object {$_ -match 'step[49]'} | Set-Content $_.FullName    #filter and save content to a new file     $content | Where-Object {$_ -match 'step[49]'} | Set-Content ($_.BaseName + '_out.log')}

Smart猫小萌

要获取目录的内容,可以使用$files = Get-ChildItem "C:\Users\gerhardl\Documents\My Received Files\"然后,您也可以遍历此变量:for ($i=0; $i -lt $files.Count; $i++) {    $outfile = $files[$i].FullName + "out"     Get-Content $files[$i].FullName | Where-Object { ($_ -match 'step4' -or $_ -match 'step9') } | Set-Content $outfile}放置foreach循环的一种更简单的方法是循环(感谢@Soapy和@MarkSchultheiss):foreach ($f in $files){    $outfile = $f.FullName + "out"     Get-Content $f.FullName | Where-Object { ($_ -match 'step4' -or $_ -match 'step9') } | Set-Content $outfile}

开满天机

如果您需要递归地在目录中循环查找特定类型的文件,请使用以下命令,该命令将过滤所有doc文件类型的文件$fileNames = Get-ChildItem -Path $scriptPath -Recurse -Include *.doc如果需要对多种类型进行过滤,请使用以下命令。$fileNames = Get-ChildItem -Path $scriptPath -Recurse -Include *.doc,*.pdf现在,$fileNames变量充当一个数组,您可以从中循环并应用业务逻辑。
打开App,查看更多内容
随时随地看视频慕课网APP