Linux文件名编码转换

独自空忆成欢 提交于 2020-04-04 06:36:19

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

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

服务器是centos,安装 convmv:yum -y install convmv。

下面看一下convmv的具体用法:

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

常用参数:

-r 递归处理子文件夹

-r 递归处理子文件夹

--notest 真正进行操作,请注意在默认情况下是不对文件进行真实操作的,而只是试验。

--list 显示所有支持的编码

--unescap 可以做一下转义,比如把%20变成空格

 

比如我们有一个utf8编码的文件名,转换成GBK编码,命令如下:

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

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

 

下面的例子,将当前文件夹下的所有文件,包括文件夹及子文件夹的文件名编码由GBK转化为UTF-8

convmv -f GBK -t UTF-8 --notest -r *

 

另:iconv转换的是文件的编码,不是文件名的编码,具体用法网上有很多例子,请自行查阅。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!