从Powershell中的file2中的file1中删除行

时间:2016-09-05 21:51:43

标签: windows file powershell

我有一个file1.txt,其中包含:

LINE1
2号线
3号线
第4行

我想从file1.txt中删除另一个file2.txt中存在的所有行:

line3中
LINE2

结果应为:

LINE1
LINE4

我尝试使用此命令,但只有在file2.txt中有一行时才有效:

Get-Content C:\file1.txt | Where-Object {$_ -notmatch $(get-content C:\file2.txt)} 

注意:我不想比较2个文件,看它们是否相同。

有什么想法吗?我对powershell很新。

2 个答案:

答案 0 :(得分:4)

Compare-Object有助于获得两个文件之间的差异。以下是一些示例代码,用于完成您所要求的内容。

$file1 = Get-Content C:\temp\file1.txt
$file2 = Get-Content C:\temp\file2.txt
$Diff = Compare-Object $File1 $File2
$LeftSide = ($Diff | Where-Object $_.SideIndicator -eq '<=').InputObject
$LeftSide | Set-Content C:\temp\file3.txt

答案 1 :(得分:1)

下一个代码段显示了两种不同的方法来实现相同的结果:

$filebefore="$env:TEMP\beforerestart.txt"    # change to match your circumstances
$file_after="$env:TEMP\after_restart.txt"    # detto

### Compare-Object way
$array = Compare-Object $(Get-Content $filebefore) $(Get-Content $file_after)
$array | where {$_.SideIndicator -eq "<="} | 
              Format-Table -Property InputObject -AutoSize -HideTableHeaders

### -NotIn operator way
$(Get-Content $filebefore) | 
     Where-Object {$_ -notIn $(Get-Content $file_after)}