我正在使用下面的powershell脚本来读取和处理一个17 MB的文本文件。输入文件包含大约200 000行和12列。目前该脚本需要将近1小时才能处理输入文件。如何优化处理时间?使用powershell的文本文件处理 - 性能问题
脚本:
$fields = Get-Content Temp.txt
$results = @()
foreach($i in $fields)
{
$field = $i -split '\t' -replace '^\s*|\s*$'
$field1 = $field[0]
$field2 = $field[1]
$field3 = $field[2]
$field4 = $field[3]
$field5 = $field[4]
$field6 = $field[5]
$field7 = $field[6]
$field8 = $field[7]
$field9 = $field[8]
$field10 = $field[9]
$field11 = $field[10]
$field12 = $field[11]
if ($field1 -eq "4803" -and $field[2].substring(0,2) -eq "60")
{
$field2 = "5000000"
}
else
{
$field2 = $field[1]
}
$details = @{
Column1 = $field1
Column2 = $field2
Column3 = $field3
Column4 = $field4
Column5 = $field5
Column6 = $field6
Column7 = $field7
Column8 = $field8
Column9 = $field9
Column10 = $field10
Column11 = $field11
Column12 = $field12
}
$results += New-Object PSObject -Property $details
}
$results | ForEach-Object { '{0} {1} ... {11}' -f $_.Column1,$_. Column1,... $_.Column12 } | Set-Content -path Temp.txt
[Environment]::Exit(0)
好吧,你为什么不开始导入这个作为csv? “else”条件也是多余的。你能提供适当的文件进行测试吗?你可以用一些东西替换所有的信息 – 4c74356b41
我也用import-csv进行了测试。我面临同样的问题。它运行1小时。但处理10000条记录只需要20秒。 – AravindhK
重复[https://social.technet.microsoft.com/Forums/scriptcenter/en-US/c5bdc740-837a-43f6-97d5-b0f0d5bf22bc/](https://social.technet.microsoft.com/Forums/脚本中心/ EN-US/c5bdc740-837a-43f6-97d5-b0f0d5bf22bc /)。 StackOverflow也不是免费的代码重新设计服务。 –