在群里看到的。記錄以備用。
sed 幫助命令:http://man.linuxde.net/sed
文件里有如下行,我想將每行的回車符替換為逗號,並將所有行合並到一行,用awk或sed怎么寫啊
TOP_COLUMN
TOP_MESSAGE
TOP_OPTIONS
TOP_TOPIC
TOP_VOTE
TOP_COLTYPE
TOP_COLUMN
TOP_MESSAGE
TOP_OPTIONS
TOP_TOPIC
TOP_VOTE
TOP_COLTYPE
awk '{{printf"%s,",$0}}'
sed ':a;N;$!ba;s#\r\n#,#g'
N 是下一行,! 對沒有影響的行用該命令,$ 最后一行;
:a 標簽
ba 跳轉到標簽
tr "\r\n" ",'
tr 命令可能會出現雙個逗號(這里換行符替換為逗號),但是已經合並為一行了,所以可以繼續替換
cat a.txt | tr "\r\n" "," | sed 's/\r\n/,/g'
## 完整替換
查看文件換行符:
用軟件notepad++
【視圖】——【顯示符號】——【顯示行尾符】。
我的操作系統是windows,所以行尾符是CR LF——對應的正則表達式是\r\n。
mac系統是CR——對應的正則表達式是\r。
unix系統是LF——對應的正則表達式是\n。
sed 命令擴展
a\ 在當前行下面插入文本。 i\ 在當前行上面插入文本。 c\ 把選定的行改為新的文本。 d 刪除,刪除選擇的行。 D 刪除模板塊的第一行。 s 替換指定字符 h 拷貝模板塊的內容到內存中的緩沖區。 H 追加模板塊的內容到內存中的緩沖區。 g 獲得內存緩沖區的內容,並替代當前模板塊中的文本。 G 獲得內存緩沖區的內容,並追加到當前模板塊文本的后面。 l 列表不能打印字符的清單。 n 讀取下一個輸入行,用下一個命令處理新的行而不是用第一個命令。 N 追加下一個輸入行到模板塊后面並在二者間嵌入一個新行,改變當前行號碼。 p 打印模板塊的行。 P(大寫) 打印模板塊的第一行。 q 退出Sed。 b lable 分支到腳本中帶有標記的地方,如果分支不存在則分支到腳本的末尾。 r file 從file中讀行。 t label if分支,從最后一行開始,條件一旦滿足或者T,t命令,將導致分支到帶有標號的命令處,或者到腳本的末尾。 T label 錯誤分支,從最后一行開始,一旦發生錯誤或者T,t命令,將導致分支到帶有標號的命令處,或者到腳本的末尾。 w file 寫並追加模板塊到file末尾。 W file 寫並追加模板塊的第一行到file末尾。 ! 表示后面的命令對所有沒有被選定的行發生作用。 = 打印當前行號碼。 # 把注釋擴展到下一個換行符以前。
^ 匹配行開始,如:/^sed/匹配所有以sed開頭的行。
$ 匹配行結束,如:/sed$/匹配所有以sed結尾的行。
. 匹配一個非換行符的任意字符,如:/s.d/匹配s后接一個任意字符,最后是d。
* 匹配0個或多個字符,如:/*sed/匹配所有模板是一個或多個空格后緊跟sed的行。
[] 匹配一個指定范圍內的字符,如/[ss]ed/匹配sed和Sed。
[^] 匹配一個不在指定范圍內的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一個字母開頭,緊跟ed的行。
\(..\) 匹配子串,保存匹配的字符,如s/\(love\)able/\1rs,loveable被替換成lovers。
& 保存搜索字符用來替換其他字符,如s/love/**&**/,love這成**love**。
\< 匹配單詞的開始,如:/\<love/匹配包含以love開頭的單詞的行。
\> 匹配單詞的結束,如/love\>/匹配包含以love結尾的單詞的行。
x\{m\} 重復字符x,m次,如:/0\{5\}/匹配包含5個0的行。
x\{m,\} 重復字符x,至少m次,如:/0\{5,\}/匹配至少有5個0的行。
x\{m,n\} 重復字符x,至少m次,不多於n次,如:/0\{5,10\}/匹配5~10個0的行。