linux显示中文乱码

linux显示中文乱码,第1张

     很多朋友都想知道linux显示中文乱码应该怎么办?下面就一起来看看吧!

      linux显示中文乱码

      一、登陆linux系统打开 *** 作终端之后,输入echo$LANG可以查看当前使用的系统语言

      在终端输入locale命令查看是否有中文语言包,如有zhcn表示已经安装了中文语言

      如果没有中文语言可以通过网上下载安装中文语言包yumgroupinstallchinese-support。

      二、临时更换语言

      如果只是临时更换linux系统的语言环境,可以通过输入设置LANG=语言名称,如中文是

      Zn_CN.UTF-8

      三、打开设置把终端的编码选择中文,或者UTF8即可

      本文章基于ThinkpadE15品牌、centos7系统撰写的。

一不小心在给文件重命名的时候输入了中文字符,结果导致文件名乱码,无法通过cat, less, rm 或者mv 之类的命令 *** 作了。

如何重新命名它,使得其恢复正常呢?

据说linux下每个文件还有一个文件节点编号,对应于每个特定的文件。可以通过find 该节点编号来执行重命名 *** 作。

ls -i res???_out.txt

144117972422752993 res???_out.txt

前面的数字串就是节点编号

find . -inum 144117972422752993 -exec mv {} res_out.txt \

如果你需要在Linux中 *** 作windows下的文件,那么你可能会经常遇到文件编码转换的问题。Windows中默认的文件格式是GBK(gb2312),而Linux一般都是UTF-8。

查看编码的方法

方法一:file

filename

方法二:在Vim中可以直接查看文件编码

:set

fileencoding

如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码的问题,那么你可以在

~/.vimrc

文件中添加以下内容:

set

encoding=utf-8

fileencodings=ucs-bom,utf-8,cp936

这样,就可以让vim自动识别文件编码(可以自动识别UTF-8或者GBK编码的文件),其实就是依照fileencodings提供的编码列表尝试,如果没有找到合适的编码,就用latin-1(ASCII)编码打开

文件编码转换

多平台方法:

iconv

提供标准的程序和API来进行编码转换;

convert_encoding.py

基于Python的文本文件转换工具;

decodeh.py

提供算法和模块来谈测字符的编码;

linux下文件编码转换:

方法一:

在Vim中直接进行转换文件编码,比如将一个文件转换成utf-8格式

:set

fileencoding=utf-8

或者

11)设置文件集合,即要对哪些文件进行 *** 作,可以使用通配符,比如我通常是对

C/C++

源程序进行编码转换

:args

*.h

*.cpp

2)给出要在每个文件上执行的命令,这里是转换编码:

:argdo

set

fenc=utf-8

|

update

方法二:

iconv

转换

5.案例:

假如说我们将windows下的一个UTF-8的文件传到linux环境下,linux环境下的系统编码是GB18030,我们cat的时候就会出现乱码,这个时候就应该想到转码了,下面我们来进行试验:

我们将windows下一个名为UTF-8.sh的文件传到linux系统中,其中UTF-8.sh的内容如下:

我是中文编码UTF-8模式~

而linux系统的系统语言设置为:

[root@sor-sys

zy]#

cat

/etc/sysconfig/i18n

LANG=zh_CN.GB18030

SYSFONT="latarcyrheb-sun16"

这个时候查看一下文件的内容及编码:

[root@sor-sys

zy]#

file

UTF-8.sh

UTF-8.sh:

UTF-8

Unicode

text,

with

no

line

terminators

[root@sor-sys

zy]#

cat

UTF-8.sh

锘挎垜鏄?腑鏂囩紪镰乁TF-8妯″纺~[root@sor-sys

zy]#

[root@sor-sys

zy]#

这个时候我们就需要转换编码了,记得使用iconv

[root@sor-sys

zy]#

iconv

-f

UTF-8

-t

GB18030

UTF-8.sh

-o

GB18030.sh

[root@sor-sys

zy]#

cat

GB18030.sh

??我是中文编码UTF-8模式~[root@sor-sys

zy]#

[root@sor-sys

zy]#

file

GB18030.sh

GB18030.sh:

Non-ISO

extended-ASCII

text,

with

no

line

terminators

[root@sor-sys

zy]#

convmv就是更改文件名编码方式的一个工具。

比如

sudo

convmv

-f

gbk

-t

utf-8

-r

–notest

/home

就是将/home目录下原来文件名是gbk编码方式的全部改为utf-8格式的。这里

-f

后面为原来的编码方式,-t

后面是要更改为的编码方式,

-r

表示这个目录下面的所有文件,

–notest

表示马上执行,而不是仅仅测试而已。另外这命令好像要root才能执行,因此要加上

sudo。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/7569491.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-07
下一篇 2023-04-07

发表评论

登录后才能评论

评论列表(0条)

保存