DOS和UNIX文本文件之间相互转换的方法&批量
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DOS和UNIX文本文件之间相互转换的方法&批量相关的知识,希望对你有一定的参考价值。
参考技术A send 批量替换单个文件修改
在Unix/Linux下可以使用file命令查看文件类型,如下:
1
file dosfile.txt
使用dos2unix
一般Linux发行版中都带有这个小工具,只能把DOS转换为UNIX文件,命令如下:
1
dos2unix dosfile.txt
安装dos2unix
1
yum -y install dos2unix
使用tr
使用tr命令拷贝标准输入到标准输出,替换或者删除掉选择的字符,只能把DOS转换为UNIX文件,命令如下:
1
tr -d '\r' < dosfile.txt > unixfile.txt
使用vim
Vim是一个vi的改进版本,可以运行在Windows和Linux平台上,使用方法如下:
注:为了能让vim可以自动识别DOS和UNIX文本文件格式,可以在.vimrc(Linux)或_vimrc(Windows)配置文件中加入如下一行设置:
使用Emacs
Emacs是一个Unix下面的文本编辑工具。它会在底部的状态栏上显示文件的信息。
使用sed
在DOS文件格式中使用CR/LF换行,在Unix下仅使用LF换行,sed替换命令如下:
使用Perl
Perl是相当直接,你添加或删除掉文件每行结尾的CR字符。
使用awk
DOS转UNIX:awk 'sub("\r 0);print $0' dosfile.txt > unixfile.txt
使用Python
DOS转UNIX:python -c "import sys; map(sys.stdout.write, (l[:-2] + '\n' for l in sys.stdin.readlines()))"< dosfile.txt > unixfile.txt
总结
还有其它DOS和UNIX文本文件的转换方法,我个人推荐使用vim命令。但是,对于大型的文件,推荐使用perl工具,你也不希望在vim或Emacs中打开几个G的文本文件。
dos与unix文件格式之间的转换
1. VI编辑器中转换
在VI中使用命令 set ff?(fileformat)可以查看文件的格式,使用set ff=dos(unix)可以设置文件的格式
2.使用sed处理(来至http://www.cnblogs.com/yangyh/archive/2011/08/12/linux.html)
Sed命令笔记
Tag: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
把每行的最后一个字符替换成空
$ sed -e ‘s/.$/abc/‘ mydos.txt > myunix.txt
把每行的最后一个字符替换成abc
该脚本的工作原理很简单:替代规则表达式与一行的最末字符匹配,而该字符恰好就是回车。我们用空字符替换它,从而将其从输出中彻底删除。如果使用该脚本并注意到已经删除了输出中每行的最末字符,那么,您就指定了已经是 UNIX 格式的文本文件。也就没必要那样做了!
2)把Linux/UNIX 文本移至 Windows 系统,使用以下脚本执行必需的格式转换:
$ sed -e ‘s/$/\r/‘ myunix.txt > mydos.txt
在每行的末尾添加\r
$ sed -e ‘s/123$/345/‘ myunix.txt > mydos.txt
每行以123结尾的行,把123替换成345
在该脚本中,‘$‘ 规则表达式将与行的末尾匹配,而 ‘/r‘ 告诉 sed 在其之前插入一个回车。在换行之前插入回车,立即,每一行就以 CR/LF 结束。请注意,仅当使用 GNU sed 3.02.80 或以后的版本时,才会用 CR 替换 ‘\r‘。
=====================================================================
DOS文件格式如何转换成UNIX文件格式
dos格式文件传输到unix系统时,会在每行的结尾多一个^M,当然也有可能看不到,但是在vi的时候,会在下面显示此文件的格式,比如 "dos.txt" [dos] 120L, 2532C 字样,表示是一个[dos]格式文件,如果是MAC系统的,会显示[MAC],因为文件格式的原因有时会导致我们的unix程序,或者shell程序出现错误,那么需要把这些dos文件格式转换成unix格式,方法是
vi dos.txt
:set fileformat=unix
:w
这样文件就转换成unix格式文件了, 一般在windows机器上编写好了文件传到unix下就可能会出现这样的情况.
用命令:set ff?
可以看到dos或unix的字样.
用:set ff=unix把它强制为unix格式
也可以用sed 这样的工具来做:
sed ‘s/^M//‘ filename > tmp_filename
其中^M是同时Ctrl+V+M按出来的,表示回车。
dos,unix格式处理的差别:DOS是回车+换行,而在UNIX下,只有回车,无换行!
sed -e ‘s/a/A/‘ t.txt > t1.txt 将t.txt中每行的第一个a转成A
sed -e ‘s/a/A/g‘ t.txt > t1.txt 将t.txt中每行的所有a转成A
3)如何把windows和UNIX格式混合的文件,变得都是unix格式的
sed -e ‘s/\r//g‘ window.txt > unix.txt
以上是关于DOS和UNIX文本文件之间相互转换的方法&批量的主要内容,如果未能解决你的问题,请参考以下文章
linux下安装dos2unix--将DOS格式文本文件转换成UNIX格式