Python输出中文失败主因是源文件、终端和解释器编码不统一为UTF-8;需确保.py文件存为UTF-8、终端切换至UTF-8(如cmd执行chcp 65001)、必要时代码中声明coding:utf-8并检查sys.stdout.encoding。

Python输出不了中文,通常是因为编码设置不匹配或环境不支持UTF-8。核心问题在于:源文件编码、终端/控制台编码、Python解释器默认编码三者不一致。只要统一为UTF-8,基本就能解决。
确保Python源文件保存为UTF-8格式
很多编辑器(如VS Code、PyCharm、Notepad++)默认可能用GBK或其他编码保存.py文件。如果文件里写了中文但保存成GBK,而Python按UTF-8读取,就会报错或显示乱码。
- 在VS Code右下角点击编码名称(如“GBK”),选择“Save with Encoding” → “UTF-8”
- 在PyCharm:File → Settings → Editor → File Encodings,把“Global Encoding”和“Project Encoding”都设为UTF-8
- 在代码开头加声明(Python 3中非必须,但显式写上更稳妥):# -*- coding: utf-8 -*-
检查并设置终端/控制台的编码
即使代码和文件是UTF-8,如果Windows命令提示符(cmd)或PowerShell默认用GBK,也会无法正常显示中文。
- Windows cmd:运行 chcp 65001(切换到UTF-8),再运行Python脚本
- PowerShell:默认支持UTF-8,但若异常可执行 [Console]::OutputEncoding = [System.Text.Encoding]::UTF8
- 推荐改用支持UTF-8更好的终端,比如Windows Terminal、VS Code内置终端,或直接用Git Bash
避免print()被重定向或捕获导致编码丢失
在某些IDE(如旧版PyCharm、Sublime Text插件)或重定向输出时(如 python script.py > out.txt),stdout可能被包装成不带UTF-8编码的流。
立即学习“Python免费学习笔记(深入)”;
Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。
- 测试当前stdout编码:print(sys.stdout.encoding)(应输出
utf-8) - 若为
None或cp936等,可在脚本开头强制设置(仅限必要场景):
import sys; sys.stdout.reconfigure(encoding='utf-8')(Python 3.7+) - 简单替代方案:用
sys.stdout.buffer.write()写bytes,但一般不推荐,优先修复环境
验证是否真正解决了
写个最小测试脚本,运行后看是否能清晰输出中文:
print("你好,世界!")
print(len("中文")) # 应输出2,不是乱码或报错
如果仍出错,重点检查终端编码和文件保存格式——90%的问题出在这两处。









