Windows文件换行符转Linux换行符

posted in: 系统相关 | 0

前段时间,有个朋友碰到由于的换行符和Linux换行符不一样,导致程序编译不通过。这个问题之前自己也碰到过,网上资料也蛮多,不过还是借此总结总结,因为发现总结+实践的方式能够让自己更好的提升。

操作系统文件换行符

首先介绍下,在ASCII中存在这样两个字符CR(编码为13)和 LF(编码为10),在编程中我们一般称其分别为'r'和'n'。他们被用来作为换行标志,但在不同系统中换行标志又不一样。下面是不同操作系统采用不同的换行符:

Linux中查看换行符

在Linux中查看换行符的方法应该有很多种,这里介绍两种比较常用的方法。

第一种使用"cat -A []" 查看,如下图所示,看到的为一个形式的换行符,r对应符号^M,n对应符号$.

windows字符编码_字符编码采用编码_windows系统字符编码

第二种使用vi编辑器查看,然后使用"set list"命令显示特殊字符:

windows字符编码_windows系统字符编码_字符编码采用编码

咦,细心的朋友发现了,怎么^M还是没显示出来,这里也是给大家提个醒,用VI的二进制模式(“vi -b []”)打开,才能够显示出^M:

字符编码采用编码_windows系统字符编码_windows字符编码

换行符转换为Linux格式

下面介绍三种方法,选择哪一种看自己喜好,当然你也可以选择第x种,^_^。

(1)第一种使用VI: 使用VI普通模式打开文件,然后运行命令"set ff=unix" 则可以将 换行符转换为Linux换行符,简单吧!命令中ff的全称为file 。

(2)使用命令"",如下所示

[root@ test]# .txt

: file .txt to UNIX ...

(3)使用sed命令删除r字符:

[root@ test]# sed -i 's/r//g' .txt

多文件处理换行符转换

通常我们都会有一批文件需要替换,比如一个目录的都要替换,我自己写了一个简单的脚本去遍历目录和子目录下的所有文件,并且将其转换为Linux换行格式。代码如下:

#!/bin/sh

#

#Check the input is valid

#0 means not valid

()

ret=1;

#Check the of

#And Check the is a

if [ $# -lt 1 ]

then

echo " use the like ./dos2u.sh []";

ret=0

elif [ ! -d $1 ]

then

echo " use an as the shell ";

ret=0

fi

$ret;

#

# all the files under the

()

=`pwd`

cd $1;

for file in `ls`

do

if [ -d $file ]

then

$file;

else

#echo $file;

#sed -i 's/r//g' $file

$file

fi

done

cd $;

$*

if [ $ret -ne 1 ]

then

exit -1

fi

$1

这个就纯当练习了,应该可以用更简单的方式去解决,比如find命令+命令,小伙伴们可以自己试一试。我这么写 主要目的是为了 以后有其他需求更便于扩展,当然还有一些bug要修改啦~~~~^_^。

参考

1. How To Files from Linux/Unix to and Vice Versa:

2. n and r?

3. 美国信息交换标准代码

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注