2011-06-16 97 views
1

我有一個包含SQL Server數據庫列表的文件。我想從文件中刪除4個系統數據庫[master,model,msdb,tempdb]。我怎樣才能做到這一點?如何從文件中刪除重複的文本?

Server1 
[DB1] 
[DB2] 
[DB3] 
[master] 
[model] 
[msdb] 
[tempdb] 
Server2 
[DB1] 
[DB2] 
[DB3] 
[master] 
[model] 
[msdb] 
[tempdb] 
Server3 
[DB1] 
[DB2] 
[DB3] 
[master] 
[model] 
[msdb] 
[tempdb] 

回答

3

一種選擇是使用-notcontains

$system = "[master]","[model]","[msdb]","[tempdb]" 
$new_file = @(get-content db_list.txt | 
    where {$system -notcontains $_}) 
$new_file | out-file db_list.txt -force 
+0

謝謝mjolinor! – Animesh 2011-06-16 12:11:08

0

,如果你只是想去掉臺詞:如果你想刪除整個塊

grep -v -E '^\[(master|model|msdb|tempdb)\]' 

perl -0133 -ne 'if ($_ !~ /^(master|model|msdb|tempdb)/) { print "["; print substr($_, 0, -1) }' 
+2

尼斯爲Unix-Y,但在PowerShell中不起作用。 – vonPryz 2011-06-16 11:31:04

1

枚舉文件,並檢查該項目不MATC一個正則表達式。這很像yi_H的grep -v示例作品。

# dbs is here an array, but anything enumerable works. 
$dbs = @("[DB1]", "[DB2]", "[DB3]", "[master]", "[model]", "[msdb]", "[tempdb]", "Server2", "[DB1]", "[DB2]", "[DB3]", "[master]", "[model]", "[msdb]", "[tempdb]", "Server3", "[DB1]", "[DB2]", "[DB3]", "[master]", "[model]", "[msdb]", "[tempdb]") 

$dbs | ? {!($_ -match "\[(master)|(model)|(msdb)|(tempdb)\]")} 
2
(Get-Content.\db.txt) | where {$_ -notmatch '^\[master|model|msdb|tempdb\]$'} | Out-File .\db.txt