[已解决]linux ubuntu unicode emoji字符显示问题

关键词:
ubuntu 终端 字符 字符集 显示 vim nvim 美化 emoji 字体替换 nerdfont nerdtree 文件目录

文章目录

    • 问题起源:
    • 字符集unicode
    • 字符问题理解了,但终端显示怎么解决?
    • 解决:修改终端字体

问题起源:

模仿B站TheCWcoc.nvim终极指南配置nvim,显示乱码
字符是下面这类:

\ue71b

字符集unicode

其实 \u 开头和 &#x 开头是一样的
1.\u是16进制 unicode字符的不同写法
2. &#则是 unicode字符的十进制的写法,&#x是十六进制写法
在线解析工具
[已解决]linux ubuntu unicode emoji字符显示问题_第1张图片
\ue71b改成进制的򐜑
[已解决]linux ubuntu unicode emoji字符显示问题_第2张图片
注意:该字符在网页上也无法正常显示,需要点击HTML按钮,左上角红框显示,但不同字体同一unicode显示也会有差别

字符问题理解了,但终端显示怎么解决?

xx@ubuntu:~$ echo $LANG
en_US.UTF-8

vim中也设置了

set encoding=utf-8
set fileencoding=utf-8  "默认为空
set fileencodings=ucs-bom,utf-8,default,latin1 "默认值

就连fileecoding,fileecodings都设置好了,就是不起作用

补充知识:VIM的编码相关,encoding, filecoding, termencoding

1,存在3个变量: 
encoding----该选项使用于缓冲的文本(你正在编辑的文件),寄存器,Vim 脚本文件等等。你可以把 'encoding' 选项当作是对 Vim 内部运行机制的设定。 
fileencoding----该选项是vim写入文件时采用的编码类型。 
termencoding----该选项代表输出到客户终端(Term)采用的编码类型。 
2,此3个变量的默认值: 
encoding----与系统当前locale相同,所以编辑文件的时候要考虑当前locale,否则要设置的东西就比较多了。 
fileencoding----vim打开文件时自动辨认其编码,fileencoding就为辨认的值。为空则保存文件时采用encoding的编码,如果没有修改encoding,那值就是系统当前locale了。 
termencoding----默认空值,也就是输出到终端不进行编码转换。
由此可见,编辑不同编码文件需要注意的地方不仅仅是这3个变量,还有系统当前locale和、文件本身编码以及自动编码识别、客户运行vim的终端所使用的编码类型3个关键点,这3个关键点影响着3个变量的设定。 

解决:修改终端字体

  1. 首先下载字体
    nerdfonts
    打开网址,选择你想要的哪种字体,推荐Hack
    [已解决]linux ubuntu unicode emoji字符显示问题_第3张图片
    按照下方的readme.md的说明下载安装就行
    也可以:
cd ~/Downloads
wget https://github.com/source-foundry/Hack/releases/download/v3.003/Hack-v3.003-ttf.zip
unzip Hack-v3.003-ttf.zip

#这里采用Regular字体
#另外也可以拷贝到用户目录下~/.local/share/fonts/
cp ./ttf/Hack-Regular.ttf /usr/share/fonts/  
  1. 打开终端,左上角选择preference->Unamed->customfont-> Hack Regular即可

[已解决]linux ubuntu unicode emoji字符显示问题_第4张图片
3. 进入该网址nerdfonts.com选择图标
[已解决]linux ubuntu unicode emoji字符显示问题_第5张图片
4. 就可以粘贴到终端啦!
[已解决]linux ubuntu unicode emoji字符显示问题_第6张图片

事到如今,终于解决,也能吃个好饭,哈哈

你可能感兴趣的:(linux,vim,linux,unicode)