1

次の形式のファイルがあります。

axel localhost> localhost>
mike localhost> STORAGE 298390/512000 (58.279296875%) localhost>
ab localhost> STORAGE 141361/512000 (27.6095703125%) localhost>
fghi localhost> localhost>
abcd localhost> STORAGE 165929/512000 (32.4080078125%) localhost>
lmno localhost> STORAGE 353073/512000 (68.9595703125%) localhost>
nuon localhost> localhost>
spar localhost> STORAGE 203766/512000 (39.798046875%) localhost>
fibo localhost> STORAGE 238204/512000 (46.52421875%) localhost>
nacci localhost> STORAGE 425737/512000 (83.1517578125%) localhost>
seldom localhost> STORAGE 69894/512000 (13.651171875%) localhost>
project localhost> STORAGE 86220/512000 (16.83984375%) localhost>
eccleston localhost> STORAGE 240084/512000 (46.89140625%) localhost>
swan localhost> STORAGE 279522/512000 (54.594140625%) localhost>

これはlistquotacyradm (Cyrus-imapd) によって生成された出力です。2 つの質問があります。

  • がある行ではlocalhost> localhost>、最初の単語を別のファイルに書き込んで、その行を削除する必要があります。
  • 他の行については、2 番目、3 番目、および最後の列を削除する必要があります。

この結果を達成するにはどうすればよいですか?

編集

期待される出力

mike 298390/512000 (58.279296875%)
ab 141361/512000 (27.6095703125%)
abcd 165929/512000 (32.4080078125%)
lmno 353073/512000 (68.9595703125%)
spar 203766/512000 (39.798046875%)
fibo 238204/512000 (46.52421875%)
nacci STORAGE 425737/512000 (83.1517578125%)

これまでの私のループは次のようになります。

while read thisline; do
    if [ $2 == "localhost>" AND $3 == "localhost>" ];then
        echo $1 >>/root/names.txt
        sed '1d' filename.txt #but this deletes only the first line
    fi

done
4

1 に答える 1

3

これを試して:

awk '/localhost> localhost>/{print $1 >"file2";next}{$2=$3=$NF=""}7' file

localhost> localhost>これにより、必要なテキストが出力され、ケースの「file2」が生成されます。

テストしていません。タイプミスがないことを願っています。

于 2013-08-15T11:13:18.440 に答える