<转> Linux查看文件编码格式及文件编码转换

    若是你须要在Linux 中操做windows下的文件 ,那么你可能会常常遇到文件 编码 转换的问题。Windows中默认的文件 格式是GBK(gb2312),而Linux 通常都是UTF-8。下面介绍一下,在Linux 中如何查看 文件 的编码 及如何进行对文件 进行编码 转换。 linux

查看文件编码
在Linux 中查看 文件 编码 能够经过如下几种方式:
    1.在Vim 中能够直接查看文件编码
:set fileencoding
便可显示文件编码格式。
若是你只是想查看 其它编码 格式的文件 或者想解决用Vim查看 文件 乱码的问题,那么你能够在
~/.vimrc 文件 中添加如下内容:

set encoding=utf-8 fileencodings=ucs-bom,utf-8,cp936

这样,就可让vim自动识别文件 编码 (能够自动识别UTF-8或者GBK编码 的文件 ),其实就是依照 fileencodings提供的编码 列表尝试,若是没有找到合适的编码 ,就用latin-1(ASCII)编码 打开。
    2. enca (若是你的系统中没有安装这个命令,能够用sudo yum install -y enca 安装 )查看 文件 编码
$ enca filename
filename: Universal transformation format 8 bits; UTF-8
CRLF line terminators
须要说明一点的是,enca对某些GBK编码 的文件 识别的不是很好,识别时会出现:
Unrecognized encoding vim

    文件编码转换
1.在Vim中直接进行转换文件 编码 ,好比将一个文件 转换成utf-8格式
:set fileencoding=utf-8

2. enconv 转换文件 编码 ,好比要将一个GBK编码 的文件 转换成UTF-8编码 ,操做以下
enconv -L zh_CN -x UTF-8 filename

3. iconv 转换,iconv的命令格式以下:
iconv -f encoding -t encoding inputfile
好比将一个UTF-8 编码 的文件 转换成GBK编码
iconv -f GBK -t UTF-8 file1 -o file2


Linux 文件名编码转换
从Linux 往windows拷贝文件 或者从windows往Linux 拷贝文件 ,有时会出现中文文件 名 乱码的状况,出现这种问题的缘由是由于,windows的文件 名 中文编码 默认为GBK,而Linux 中默认文件 名 编码 为UTF8,因为编码 不一致,因此致使了文件 名 乱码的问题,解决这个问题须要对文件 名 进行转码。

在Linux 中专门提供了一种工具convmv进行文件 名 编码 的转换 ,能够将文件 名 从GBK转换 成UTF-8编码 ,或者从UTF-8转换 到GBK。

首先看一下你的系统上是否安装了convmv,若是没安装的话用:
yum -y install convmv
安装。
下面看一下convmv的具体用法:

convmv -f 源编码 -t 新编码 [选项] 文件 名

经常使用参数:
-r 递归处理子文件 夹
--notest 真正进行操做,请注意在默认状况下是不对文件 进行真实操做的,而只是试验。
--list 显示全部支持的编码
--unescap 能够作一下转义,好比把%20变成空格
好比咱们有一个utf8编码 的文件 名 ,转换 成GBK编码 ,命令以下:

convmv -f UTF-8 -t GBK --notest utf8编码 的文件 名

这样转换 之后"utf8编码 的文件 名 "会被转换 成GBK编码 (只是文件 名 编码 的转换 ,文件 内容不会发生变化)。 windows

 dos 和unix 文本文件格式 工具

    dos 和unix 文本文件格式主要是回车的编码方式不一样。原来unix下的回车是用0x0A表示的,而dos下的回车则是0x0D0A。能够是使用ultraedit 中的hex编辑查看。在实际工做中遇到的问题。openldap 的启动文件须要从配置文件slapd.conf 获取数据文件的目录。                                                                             ·LANG=C grep '^directory[[:space:]]+[[:print:]]' /etc/openldap/slapd_pri.conf | sed s,^directory,,·在dos格式下始终不能正确获取到directroy的值。 编码

    转换方法:1.在windows中能够ultraedit 保存为unix格式。在linux中可使用dos2unix工具进行转换。 spa

                   2.用 vim 转换,用vim打开文本文件,用 set fileformat=unix 转换
                      vim test.txt 
                      :set fileformat=unix
                       :wq
unix

相关文章
相关标签/搜索