zoukankan      html  css  js  c++  java
  • linux 出现中文乱码,该如何处理?

    好几天了,一打开机器就是跳出如下错误

    Last login: Thu May 19 10:43:20 2016 from 192.168.10.104
    -bash: VimCrypt~01!Lt3?? command not found
    -bash: l-T???#?: command not found

    然后发现中文乱码了。。。。。。。

    ?????????  ??????

    找到解决的办法了,所以将这个解决的方案,共享一下:

     我们知道我们的操作系统是无所谓中文版和英文版的,无论是windows还是Linux,系统发行的时候全世界都是一样的内核,系统呈现给我们是英文还是中文,完全取决于你选择的语言包。不同国家的人在安装使用的时候选择属于自己国家的语言包,应用程序中的语言也不是写死的,它根据系统的设置来调用相关的语言,所以,一个应用程序写出来不经过修改,全世界不同国家的用户都可以以母语界面使用它,这就是所谓的internationalization(国际化),简称 i18n。这也是未来软件的发展趋势。 

        那么,如果我在系统中安装了不同的语言包和不同的字体,系统是如何判断我所要的语言界面并调用相关的字体的呢? 系统中那些文件和变量在控制这些呢? 

        可以使用locale命令,查看当前系统默认采用的字符集

    1
    # locale

        在redHat/CentOS系统下,记录系统默认使用语言的文件是/etc/sysconfig/i18n,如果默认安装的是中文的系统,i18n的内容如下: 

    1
    2
    3
    LANG="zh_CN.UTF-8" 
    SYSFONT="latarcyrheb-sun16" 
    SUPPORTED="zh_CN.UTF-8:zh_CN:zh"
    • 其中LANG变量是language的简称,稍微有英语基础的用户一看就看出来这个变量是决定系统的默认语言的,即系统的菜单、程序的工具栏语言、输入法默认语言等。

    • SYSFONT是system font的简称,决定系统默认用哪一种字体。

    • SUPPORTED变量决定系统支持的语言,即系统能够显示的语言。

        需要说明的是,由于计算机起源于英语国家,因此,不管你把这些变量设置成什么,英语总是默认支持的,而且不管用什么字体,英文字体总包含在其中。 

    二、安装中文语言包与编码设置

    那么如何显示中文呢?

    1、系统必须安装中文语言包才行(中文字体)

    1
    # yum -y groupinstall chinese-support

    2、仅仅有语言包还不行,我们得设置相应的字符集编码

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    ## 临时生效
    # export LANG="zh_CN.UTF-8"    # 设置为中文
    # export LANG="en_US.UTF-8"    # 设置为英文,我比较喜欢这样 export LANG=C
     
    ## 永久生效, 编辑/etc/sysconfig/i18n(最好reboot一下)
    LANG="zh_CN.UTF-8"
     
     
    ## 或者编辑 /etc/profile 配置文件,添加如下一行
    export LANG="zh_CN.UTF-8"
    # 重新载入
    /etc/profile
     
    ## 查看当前的字符集
    echo $LANG

        好了,经过上面的设置,在系统本身应该就能够支持中文显示了。

     

    三、远程终端乱码

    同样,要解决乱码问题,需要保证2两点:

    • 选择支持中文的字体

    • 终端软件的字符编码

    常见终端软件设置:

    Xshell:

    wKiom1bSgAWD2Lr_AAD83uq-hXQ224.png

    wKiom1bSgAXS8UUhAAEBW1JfgYA535.png

    SecureCRT:

    wKiom1bSgVCzBDwAAAEI05o_INY291.png

    四、Linux - Windows 相互修改文件乱码

        把文件从windowss拷贝到到linux,拷贝过去后经常发现中文显示乱码。原因是Windows中默认的文件格式是 GBK(gb2312),而Linux一般都是UTF-8。比较繁琐的方法是在windows下用程序把内容转换为utf-8编码格式的,但是相当麻烦, 而且遇到一个文件转一回。下面介绍一下,在Linux中如何一劳永逸的解决这个问题,查看文件的编码及如何进行对文件进行编码转换。

        为了避免这些问题,最好的方式就是统一编码。对于文本文件,都统一保存为UTF8格式,windows下面不要使用word,记事本,推荐Sublime text, 或者 notepad++。

    本文出自 “Share your knowledge” 博客,请务必保留此出处http://skypegnu1.blog.51cto.com/8991766/1545449

  • 相关阅读:
    Representation Data in OpenCascade BRep
    Render OpenCascade Geometry Surfaces in OpenSceneGraph
    Render OpenCascade Geometry Curves in OpenSceneGraph
    OpenCascade Shape Representation in OpenSceneGraph
    Geometry Surface of OpenCascade BRep
    Geometry Curve of OpenCascade BRep
    Tyvj2017清北冬令营入学测试
    Spfa算法模板
    洛谷1016 旅行家的预算
    洛谷1290 欧几里得的游戏
  • 原文地址:https://www.cnblogs.com/chaochao520/p/5508682.html
Copyright © 2011-2022 走看看