WINDOWS下記事本編寫的文檔和LINUX下VIM或者GEDIT等編寫的文檔的不同。
例如WINDOWS下編寫的SH指令碼,放到LINUX下執行可能會出錯。
解決方案:
原因是:Windows下分行符號號是“\r\n”,而linux下是“\n”沒有”\r”,當shell檔案是在Windows下編寫的時候,所有的分行符號都是“\r\n”,shell下是沒辦法執行這個檔案的,會提示以上錯誤。請在ultraedit下將該檔案執行“File->conversions->Dos to Unix”,執行這個轉化後的sh檔案能夠直接在linux下執行。這步操作能夠就是取消”\r”符號。
在 client 端選 ascii 即可。
若已經用 binary 完成 transfer ,那就試試:
cat ms.txt | col -b > linux.txt
Linux下建立的文檔在Windows下用記事本開啟會擠在一起(沒有了分行符號),原因是記事本不支援\n換行(它只支援\r\n形式的換行),
解決方案:
儲存成doc格式用Word開啟就可以了,這樣在Linux下用Vim或者gedit建立doc文檔(屬於純文字doc文檔)(或者建立成.c文檔,在Windows中可以用VC6.0來瀏覽。)。要開啟也可以直接輸入命令: (注意,如果檔案名稱是中文,那有可能找不到,須要ls一下,然後複製檔案名稱,然後再gedit 粘貼檔案名稱)
gedit xx.doc
或者vim xx.doc(不推薦,vim可能不支援繁體字)
或者直接找到檔案,點擊,用Open Office來開啟,選擇字元集(系統),字元(SYSong18030),語言(中文簡體),換段落:
1. CR&LF,即\r\n,這是Windows下記事本的格式,Linux是完全支援的;(推薦)
2. CR,即\r,記事本不支援,沒有換行效果,也沒有\r效果;Word下有換行效果,也有\r,其\r效果是:在每一行的末尾,預設的游標定位是下一行的行首,也就是說在行尾輸入的內容實際上是下一行的行首,\r才是真正的換行。而\n是斷行符號,原意是打字機的紙張往下移動一位,後來在linux/unix系統下,\n成為了實際上的分行符號。
3. LF,即\n,linux/unix系統下的分行符號。
如果是Windows下編寫的doc文檔,在Linux下查看(用Open Office)一般都會亂碼,
解決方案:
先用Open Office開啟,然後再全選,把字型設定為SYSong18030,OK中文簡體和繁體都顯示正常了。
\r是斷行符號符,\n是分行符號,各個系統的換行標誌:
win 用 \r\n
linux/unix 用 \n
Mac OS 用 \r
CR用符號'\r'表示, 十進位ASCII代碼是13, 十六進位代碼為OxOD
LF使用'\n'符號表示, ASCII代碼是10, 十六製為0x0A
所以Windows下用的是OAOD,即CR&LF,
linux/unix用的是OA,即LF
MacOS用的是OD,即CR
來曆:電腦還沒有出現之前,有一種叫做電傳打字機(Teletype Model 33)的玩意,每秒鐘可以打10個字元。但是它有一個問題,就是打完一行換行的時候,要用去0.2秒,正好可以打兩個字元。要是在這0.2秒裡面,又有新的字元傳過來,那麼這個字元將丟失。
於是,研製人員想了個辦法解決這個問題,就是在每行後面加兩個表示結束的字元。一個叫做“斷行符號”,告訴打字機把列印頭定位在左邊界;另一個叫做“換行”,告訴打字機把紙向下移一行。這就是“換行”和“斷行符號”的來曆,從它們的英語名字上也可以看出一二。
後來,電腦發明了,這兩個概念也就被般到了電腦上。那時,儲存空間很貴,一些科學家認為在每行結尾加兩個字元太浪費了,加一個就可以。於是,就出現了分歧。Unix 系統裡,每行結尾只有“<換行>”,即“\n”;Windows系統裡面,每行結尾是“<斷行符號><換行>”,即“ \r\n”;Mac系統裡,每行結尾是“<斷行符號>”。一個直接後果是,Unix/Mac系統下的檔案在Windows裡開啟的話,所有文字會變成一行;而Windows裡的檔案在Unix/Mac下開啟的話,在每行的結尾可能會多出一個^M符號。
(在不同平台間使用FTP軟體傳送檔案時, 在ascii文字模式傳輸模式下, 一些FTP用戶端程式會自動對換行格式進行轉換. 經過這種傳輸的檔案位元組數可能會發生變化. 如果你不想ftp修改原檔案, 可以使用bin模式(二進位模式)傳輸文本)
\n和\r在C語言中的用法:
#include <stdio.h>
int main()
{
printf("938517\r10086\n");
return 0;
}
無論是Linux系統還是Windows平台,輸入均是
10086
因為\r已經換行了,所以938517就不再顯示了。而\n並不是真正意義上的換行,它實際上是把紙張(或螢幕)向下移動一位(以便顯示下一行的內容)。