
以下の形式のファイルがあります -
root 0 system 0
bin 2
sys 3
security 7
cron 8
audit 10
lp 11
daemon 1 staff 1
bin 2 bin 2
sys 3
adm 4
sys 3 sys 3
そして、シェルスクリプトを使用してフォーマットされた新しいファイルに変換したい -
root system,bin,sys,security,cron,audit,lp
daemon staff
bin bin,sys,adm
sys sys
答え1
すぐに使えるawk
ソリューション:
awk 'NF==4 && NR>1 {printf "\n" ; }
NF==4 { printf "%-10s %s",$1,$3}
NF==2 { printf ",%s",$1}
END { printf "\n" ; } '
どこ
NF
フィールド番号(列番号)NR
レコード番号(行番号)- さまざまな条件で印刷内容を選択します。
printf
末尾の改行は印刷されません。
答え2
perl -lane '
if ( @F == 4 ) { # num fields are 4
print $result if $. > 1; # in case we"re not @ BOF, show result
$result = join "\t", @F[0,2]; # initialize result
} else {
$result .= ",$F[0]"; # append result
}
eof && print $result; # on the last line, show result
' filename
答え3
perl -0pe 's/\h+\d+\h*\n\h+/,/g; s/\h+\d+//g' ex
- 最初の置換は数字を置き換え、その後
\n...spaces
に,
- 2 番目の置換により、他の数字が削除されます。