处理Linux中文路径乱码问题

本文介绍了解决从Linux拷贝文件到Windows或反之过程中出现的中文文件名乱码问题的方法。主要原因是Windows默认使用GBK编码,而Linux使用UTF-8编码。文章提供了两种解决方案:一是使用支持指定字符编码的工具;二是利用Linux工具convmv进行文件名编码转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

方法一:
使用允许指定字符编码格式的上传工具,如使用xshell5的xftp5工具上传文件时,注意修改配置,让窗口显示中文文件名能以Linux默认的UTF-8作为编码上传:



方法二:
对于本来已经存在于Linux上的文件,在Linux中专门提供了一种工具进行文件名编码的转换,可以将文件名从GBK转换成UTF-8编码,或者从UTF-8转换到GBK。
服务器是centos,安装 convmv:yum -y installconvmv。
下面看一下convmv的具体用法:
convmv -f 源编码 -t 新编码 [选项] 文件名
常用参数:
-r 递归处理子文件夹
-r 递归处理子文件夹
--notest真正进行操作,请注意在默认情况下是不对文件进行真实操作的,而只是试验。
--list 显示所有支持的编码
--unescap 可以做一下转义,比如把%20变成空格
 
比如我们有一个utf8编码的文件名,转换成GBK编码,命令如下:
convmv -f UTF-8 -t GBK --notestutf8编码的文件名
这样转换以后”utf8编码的文件名”会被转换成GBK编码(只是文件名编码的转换,文件内容不会发生变化)
 
下面的例子,将当前文件夹下的所有文件,包括文件夹及子文件夹的文件名编码由GBK转化为UTF-8
convmv -f GBK -t UTF-8 --notest -r *
 
另:iconv转换的是文件的编码,不是文件名的编码,具体用法网上有很多例子,请自行查阅。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值