原理: linux
在Linux中,文本文件用"\n"表示回车换行,而Windows用"\r\n"表示回车换行。因此在Linux中使用Windows的文本文件经常会出现错误vim
由于装了双系统,因此有时一些文件在两个系统之间共享,不过以前一直没有很在乎这个问题.在windows系统中用Word或者Notepad++打开文件,在linux系统中一直用的是vim编辑器,不过昨天在命令行界面就只能用vi了..郁闷!! 中文支持都是个头痛的问题,在windows编辑过的文本文件每行末尾都会以^M以结尾...windows
----------------------------------------------------bash
Linux提供了两种文本格式相互转化的命令:dos2unix和unix2dos,dos2unix把"\r\n"转化成"\n",unix2dos把"\n"转化成"\r\n"。编辑器
Ubuntu 7.10中默认没有dos2unix或者unix2doside
提示要安装tofrodos这个包( Converts DOS <-> Unix text files, alias tofromdos )工具
$sudo apt-get install tofrodos测试
dos2unix --> 将windows文本文件转化为linux格式spa
unix2dos --> 将linux文本文件转化为windows格式命令行
用法:
man dos2unix
man unix2dos
----------------------------------------------------
使用linux系统中自带的流文本编辑器sed
DOS/Windows和Linux/Unix的文件换行回车格式不一样, 基于 DOS/Windows 的文本文件在每一行末尾有一个CR(回车)和LF(换行),而 UNIX 文本只有一个换行..
1. 把Dos/Windows下的文件移至Linux/Unix系统
虽然不少程序不在意 DOS/Windows 格式的 CR/LF 文本文件,可是有几个程序却在意 -- 最著名的是 bash,只要一遇到回车,它就会出问题。如下 sed 调用将把 DOS/Windows 格式的文本转换成可信赖的 UNIX 格式:
$ sed -e 's/.$//' mydos.txt > myunix.txt
该脚本的工做原理很简单:替代规则表达式与一行的最末字符匹配,而该字符刚好就是回车。咱们用空字符替换它,从而将其从输出中完全删除。若是使用该脚本并注意到已经删除了输出中每行的最末字符,那么,您就指定了已是 UNIX 格式的文本文件。也就不必那样作了!
2. 把Linux/UNIX 文本移至 Windows 系统,使用如下脚本执行必需的格式转换:
$ sed -e 's/$/\r/' myunix.txt > mydos.txt
在该脚本中,'$' 规则表达式将与行的末尾匹配,而 '\r' 告诉 sed 在其以前插入一个回车。在换行以前插入回车,当即,每一行就以 CR/LF 结束。请注意,仅当使用 GNU sed 3.02.80 或之后的版本时,才会用 CR 替换 '\r'。
----------------------------------------------------
听说还能够用vim来处理(未测试):
在 Vim 的命令模式中输入 :%s/^M$//g 后,回车即会自动删除该文件中的全部 ^M 字符
命令分析:
%指匹配整个文件, s是置换的意思, ^M 注意要用Ctrl + V和Ctrl + M来输入,M后面的$表明匹配行尾的内容(用空格替换), 最后的g则表示每行中匹配到的内容都要置换
----------------------------------------------------
使用tr 命令实现:
1. 使用相似于这样的表示法: tr abc xyz ,它表示用字母“x”去替换出现的全部字母“a”,用字母“y”去替换全部字母“b”,用字母“z”去替换全部字母“c”。
2. tr a-z A-Z 将用对应的大写字母来替换全部的小写字母(例如,它将“no smoking”转换成“NO SMOKING”)。
3. 当您在 vi 编辑器中想强调正在编辑的文本的某一部分时,使用这一特殊技巧很是方便。只要按一下 Escape 键,而后按 : 键,再输入 2,4!tr 'a-z' 'A-Z' ,最后按一下 Return 键。如今,从第 2 行到第 4 行的字母就都转换成了大写字母。
4. 另外,当有人给您发送了一个在 Mac OS 或 DOS/Windows 机器上建立的文本文件时,您会发现 tr 很是有用。若是没有将文件保存为使用 UNIX 换行符来表示行结束这种格式,则须要将这样的文件转换成本机 UNIX 格式,不然一些命令实用程序不会正确地处理这些文件。Mac OS 的行尾以回车字符结束,许多文本处理工具将这样的文件做为一行来处理。为了纠正这个问题,能够用下列技巧:
* Mac -> UNIX: tr '\r' '\n' < macfile > unixfile
* UNIX -> Mac: tr '\n' '\r' < unixfile > macfile
----------------------------------------------------