當我們在windows中寫好文件后在Linux或者Unix中打開都會有^M這樣的字符,那么你知道Linux如何處理文本文件內容中^M嗎?下面我們就跟小編一起去看看Linux處理文本文件內容中^M的方法。
在Linux下查看文件格式:
# file filename
# 20140304110001.csv: ISO-8859 text //不帶有^M
# 20140304110002.csv: ISO-8859 text, with CRLF line terminators //帶有^M
Windows下處理的文件就帶有CRLF行終止符。
以下有幾種處理方式:
1. vi命令行模式下輸入
:%s/^M$//g?# 去掉行尾的^M。
:%s/^M//g?# 去掉所有的^M。
:%s/^M/[ctrl-v]+[enter]/g?# 將^M替換成回車。
:%s/^M//r/g?# 將^M替換成回車。
2. 使用sed命令。和vi的用法相似:
# sed -e 's/^M//n/g'filename
3. 使用命令
使用dos2unix命令,一般的*nix發布版本都帶有這個小工具,即Windows - *nix文件轉換。
格式: dos2unix filename
轉換多個文件
格式:dos2unix file1 file2 file3 ….
上面轉換文件的時候都會修改原來的文件,使用 -k參數,或者 -n參數可以不改變文件屬性。
格式:dos2unix -n oldfile newfile //新建一個文件,保持源文件不變
格式:dos2unix -k filename //保持文件時間戳不變
同樣工具提供了*nix - windows文件格式轉換命令:unix2dos,參數同dos2unix。
*注:"^M",需要使用Ctrl + V + Ctrl + M鍵入,而不是數字6上面的^+字母M。
以上就是小編為大家介紹Linux處理文本文件內容中^M的方法,當然您認為寫得不好或者有錯的地方,希望得到您的建議和指正,謝謝。
|
新聞熱點
疑難解答