Linux下去掉^M有哪些方法
Linux繼承了Unix以網(wǎng)絡(luò)為核心的設(shè)計(jì)思想,是一個(gè)性能穩(wěn)定的多用戶網(wǎng)絡(luò)操作系統(tǒng)。對(duì)于斷元字符 ^M,可能很多用戶不知道怎么去掉,本文通過(guò)四種方法給大家介紹了Linux下去掉^M的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
第一種方法:
cat -A filename 就可以看到windows下的斷元字符 ^M
要去除他,最簡(jiǎn)單用下面的命令:
dos2unix filename
第二種方法:
sed -i ‘s/^M//g' filename
#注意:^M的輸入方式是 Ctrl + v ,然后Ctrl + M
第三種方法:
#vi filename
:1,$ s/^M//g
^M 輸入方法: ctrl+V ,ctrl+M
第四種方法:
#cat filename |tr -d ‘/r' > newfile
#^M 可用 /r 代替
補(bǔ)充:Linux基本命令
?、賚s 意為list 列出當(dāng)前文件夾中的文件
-l 顯示文件的屬性 可用ll來(lái)表示
②alias 別名 看看是否有別名的文件
?、踓d dir 跳躍目錄 -P選項(xiàng) 將路徑中的鏈接文件替換成鏈接指向的文件路徑
?、躳wd 查看當(dāng)前工作的文件夾名 使用-P的選項(xiàng),會(huì)直接進(jìn)入到其中,相當(dāng)于cd
相關(guān)閱讀:Linuxshell腳本不執(zhí)行問(wèn)題實(shí)例分析
shell腳本不執(zhí)行問(wèn)題:某天研發(fā)某同事找我說(shuō)幫他看看他寫(xiě)的shell腳本,死活不執(zhí)行,報(bào)錯(cuò)。我看了下,腳本很簡(jiǎn)單,也沒(méi)有常規(guī)性的錯(cuò)誤,報(bào)“:badinterpreter:Nosuchfileordirectory”錯(cuò)??催@錯(cuò),我就問(wèn)他是不是在windows下編寫(xiě)的腳本,然后在上傳到linux服務(wù)器的……果然。原因:在DOS/windows里,文本文件的換行符為rn,而在*nix系統(tǒng)里則為n,所以DOS/Windows里編輯過(guò)的文本文件到了*nix里,每一行都多了個(gè)^M。解決:
1)重新在linux下編寫(xiě)腳本;
2)vi:%s/r//g:%s/^M//g(^M輸入用Ctrl+v,Ctrl+m)附:sh-x腳本文件名,可以單步執(zhí)行并回顯結(jié)果,有助于排查復(fù)雜腳本問(wèn)題。
Linux下去掉^M相關(guān)文章: