說實話,雖然對shell編程包括awk有所了解,但是對sed的多行與一行的處理還是不甚理解,在網上搜羅了一篇文章覺得還不錯,記錄一下:
今天一個工程師問我,怎么將一個文件中的多行轉換成一行。
我給出了如下三種方法:
1. 采用awk
awk BEGIN{RS=EOF}'{gsub(/\n/," ");print}' file
說明:awk默認將記錄分隔符(record separator即RS)設置為\n,此行代碼將RS設置為EOF(文件結束),也就是把文件視為一個記錄,然后通過gsub函數將\n替換成空格,最后輸出。
2. 采用sed
sed ':a ; N;s/\n/ / ; t a ; ' file
說明:sed默認只按行處理,N可以讓其讀入下一行,再對\n進行替換,這樣就可以將兩行並做一行。但是怎么將所有行並作一行呢?可以采用sed的跳轉功能。:a 在代碼開始處設置一個標記a,在代碼執行到結尾處時利用跳轉命令t a重新跳轉到標號a處,重新執行代碼,這樣就可以遞歸的將所有行合並成一行。
3. cat file | xargs
說明:這可能是最簡單的一種方式。
This manual page documents the GNU version of xargs. xargs reads argu-
ments from the standard input, delimited by blanks (which can be pro-
tected with double or single quotes or a backslash) or newlines
上面是man手冊對xargs的說明。其實xargs就是對shell命令行參數限制做的一個擴展。
這條命令的含義也很簡單,將file中的內容作為參數傳給X程序
如果用echo作為X程序,則命令為:
cat file | xargs echo
此命令和cat file | xargs 行為一致,因為xargs的默認行為就是打印輸出。
unix的一些工具設計很巧妙,每一項工具僅專注於完成一個功能。往往組合起來就能實現很強大的功能。2年前剛剛工作的時候非常喜歡玩弄各種工具,拼湊完成運維的任務。和代碼完成的功能一樣,但卻能順手拈來,省掉了冗長的程序代碼。