VSCode怎么在内置终端中配置Fish Shell并解决中文乱码
VSCode终端设Fish Shell为默认需先安装fish并配置settings.json,添加terminal.integrated.defaultProfile与profiles对应条目,再关闭重开终端;中文乱码需在config.fish中设置LANG和LC_ALL,并在VSCode中配置中文字体链。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
VSCode 终端怎么设 Fish Shell 为默认
想把VSCode的默认终端换成Fish Shell?第一步,得先确保Fish已经在你的系统里安家了。打开任意终端,运行fish --version命令,如果能看到版本号输出,那就恭喜你,可以直接进行下一步。如果系统提示命令未找到,那就得先去fishshell.com官网下载安装包,把Fish请进门。
这里有个关键提醒:Windows用户需要注意,原生的CMD或PowerShell无法直接替换为Fish。通常的路径是借助WSL(Windows Subsystem for Linux)或者在Git Bash这样的环境中自行搭建Fish。
环境准备好之后,真正的配置在VSCode里进行。打开VSCode设置(快捷键Ctrl + ,),搜索terminal.integrated.defaultProfile.linux(Linux系统)或terminal.integrated.defaultProfile.osx(macOS系统)。点击搜索结果旁的“在settings.json中编辑”链接,把下面这段配置加进去:
"terminal.integrated.defaultProfile.linux": "fish",
"terminal.integrated.profiles.linux": {
"fish": {
"path": "fish"
}
}
macOS用户的操作类似,只需把上面配置中的linux替换成osx即可。配置保存后,必须关闭所有已经打开的终端面板,然后按Ctrl + Shift + `新建一个终端。这是因为旧的终端会话不会自动加载新的配置文件,只有新开的终端才会乖乖认领Fish作为默认Shell。
Fish 启动时 locale 没生效导致中文乱码
配置好了,但一打开终端,中文全成了乱码?这恐怕是新手切换至Fish时最常遇到的“当头一棒”。问题根源在于,Fish Shell的设计很独立,它不会自动读取你熟悉的~/.bashrc或~/.zshrc文件。所以,即使你在之前的Shell里把LANG设置成了zh_CN.UTF-8,Fish启动后,你运行locale命令,很可能看到的还是LANG=C。这个“C” locale,就是导致中文显示异常的主要元凶。
解决办法很直接:我们需要在Fish自己的地盘上设置环境变量。打开(或创建)Fish的配置文件:~/.config/fish/config.fish。
- 首先,确保配置目录存在:
mkdir -p ~/.config/fish - 然后,编辑这个文件,添加核心的两行配置:
set -gx LANG zh_CN.UTF-8 set -gx LC_ALL zh_CN.UTF-8
这里用set -gx命令,是为了将变量设置为全局(-g)并导出(-x)到子进程。加上LC_ALL是为了覆盖所有locale类别,有些老工具只认它。
修改完成后,务必重新启动一个Fish终端。再次运行locale命令,确认输出中的LANG和LC_ALL都已经变成了zh_CN.UTF-8(如果你偏好英文环境,也可以设为en_US.UTF-8)。
VSCode 集成终端里 Fish 输出中文仍是方块或问号
环境变量明明设对了,locale命令也显示正常,为什么VSCode终端里显示的中文还是一个个小方块或者问号?别急,这很可能不是Fish的错,而是VSCode终端自身的字体渲染问题。终端里显示什么字体,和Shell进程是两套系统。
关键操作在VSCode的设置里。搜索terminal.integrated.fontFamily这个设置项,它的值不能只填一个字体名字。正确的做法是填入一个“字体族”链,用逗号分隔,确保其中包含能显示中文的字体。例如:
"Cascadia Code", "Microsoft YaHei", "Noto Sans CJK SC", "monospace"
这个链式配置的意思是:优先尝试使用“Cascadia Code”字体显示,如果该字体缺少某个中文字形,就向后备字体“Microsoft YaHei”(微软雅黑)或“Noto Sans CJK SC”求助,最后再回退到系统等宽字体。
这里有两点需要特别注意:
- 必须使用链式写法:只写一个“Cascadia Code”是没用的,因为它本身不包含完整的中文字形库。
- 注意字体可用性:在Windows上,如果你没有安装“Cascadia Code”,可以换成
"Consolas", "SimSun", "monospace"。但要注意,“SimSun”(宋体)不是等宽字体,可能会导致终端字符对齐错乱,影响观感。
如果修改设置后问题依旧,可以尝试更直接的方法:在VSCode的终端窗口内右键点击,选择“属性”或类似菜单,找到字体设置,手动选择一个你系统里真实存在且支持中文的等宽字体(比如就选“Cascadia Code”)。这一步图形化的操作常常被忽略,但往往是解决问题的临门一脚。
Python / Node.js 在 Fish 终端里 print 中文报 UnicodeEncodeError
最让人头疼的情况来了:终端能显示中文了,但一运行Python或Node.js脚本打印中文,就直接抛出一个UnicodeEncodeError: 'utf-8' codec can't encode character...的错误。这其实是一种“假象”。错误的根本原因,通常是Fish设置的环境变量没有成功传递给Python这样的子进程,或者Python检测sys.stdout.encoding时得到了一个None或错误的值,于是编码就乱了套。
怎么验证?在Fish终端里运行这行命令:python -c "import sys; print(sys.stdout.encoding)"。如果输出的不是utf-8
除了前面强调的要在~/.config/fish/config.fish中用set -gx正确设置变量,还需要检查Fish的“通用变量”机制。可以运行fish -c "set -U fish_user_paths"测试,如果报错提示“not a universal variable”,可能意味着你的Fish版本较旧,某些机制不太一样。
一个稳妥的检查流程是:
- 确保
~/.config/fish/config.fish文件存在且可读。 - 打开文件,确认每一行
set -gx赋值语句都是完整的,没有被注释掉,后面都跟着明确的值,避免空行或格式错误干扰解析。 - 新开一个终端,执行
env | grep LANG,必须能清晰看到LANG=zh_CN.UTF-8这样的输出。这证明变量已经成功置于环境之中。
Fish的变量作用域规则比Bash更严格,set -gx看似是全局导出,但在某些复杂的场景下,比如VSCode通过特定路径启动Shell,或者存在嵌套的子Shell时,变量仍有可能“走丢”。如果以上步骤都确认无误,问题通常就能解决。
当然,在调试Python脚本时,可以临时在脚本开头加上import sys; sys.stdout.reconfigure(encoding='utf-8')来强制指定编码。但这只是个权宜之计,是“创可贴”而非“根治术”,真正的解决方案还是确保Shell环境本身的编码设置正确且稳固。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
VSCode快速打开文件:使用Ctrl+P组合键定位项目资源技巧
Ctrl+P搜不到文件?问题可能出在工作区索引上 遇到Ctrl+P搜不到文件的情况,先别急着怀疑快捷键失灵。十有八九,问题根源在于文件压根没被索引进工作区。这个功能依赖的是对当前工作区的完整索引,而非全局磁盘扫描。 Ctrl+P搜不到文件的三个典型原因 VSCode的Ctrl+P(在macOS上是C
Sublime如何实现代码实时查错_Sublime安装SublimeLinter插件教程
Sublime如何实现代码实时查错_Sublime安装SublimeLinter插件教程 先说一个核心事实:Sublime Text 编辑器本身并不具备代码检查能力。 它实现实时查错,靠的是一个名为 SublimeLinter 的框架,再加上外部的命令行工具(比如 ESLint、Flake8)来协同
git重命名分支的正确操作【详解】
Git分支重命名:一个操作,三重陷阱 把git branch -m当成“一键改名”来用,是很多开发者踩坑的开始。这个命令只动了本地,远程仓库里旧分支依然挂着,新分支压根不存在。结果呢?CI CD流水线可能还在跑旧分支,Pull Request的指向一片混乱,团队协作瞬间陷入泥潭。 最安全的路径:在当
VSCode编辑器状态栏隐藏_追求极简全屏开发环境设置
VSCode状态栏消失通常因误触发View: Toggle Status Bar命令、进入Zen Mode或系统全屏模式,而非崩溃;恢复只需再次执行该命令、退出Zen Mode(Esc)或取消F11全屏。 先别慌,VSCode的状态栏其实不是“丢了”,它大概率只是被关掉了。绝大多数情况下,这都是一次
VSCode配置FastAPI异步 接口开发VSCode自动文档补全
VSCode中FastAPI接口不提示async await,根本原因是Pylance默认未开启异步函数深度推导,需启用类型检查、显式标注返回类型、规范Pydantic联合类型写法、避免async中混用yield。 VSCode里FastAPI接口不提示async await怎么办 很多开发者都遇到
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

