Python中文输出设置方法详解
时间:2026-01-27 12:48:39 189浏览 收藏
golang学习网今天将给大家带来《Python输出中文配置方法》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习文章或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!
Python默认支持中文,但终端编码(如Windows cmd默认GBK)、文件未声明UTF-8编码、open()未指定encoding、子进程/日志/Web响应等输出通道编码不匹配,会导致UnicodeEncodeError或乱码。

Python 程序默认能输出中文,但实际运行时经常出现 UnicodeEncodeError 或乱码,根本原因不是 Python 不能处理中文,而是终端/控制台、文件编码、IDE 输出通道或系统 locale 设置不匹配。
Windows 控制台默认不支持 UTF-8(尤其旧版 cmd)
cmd 默认使用 GBK 编码,而 Python 3 字符串是 Unicode,print("你好") 会尝试用系统编码(GBK)输出 UTF-8 字节流,导致报错或显示为乱码。
- 临时解决:在脚本开头加
import io import sys sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
- 更稳妥做法:启动 cmd 前执行
chcp 65001(切换为 UTF-8 模式),再运行脚本 - PowerShell 默认支持 UTF-8,推荐替代 cmd;VS Code 的集成终端也默认 UTF-8,但需确认设置:
"terminal.integrated.defaultProfile.windows": "PowerShell"
Python 文件本身没声明编码
如果源文件含中文字符(如字符串字面量、注释),且未声明编码,Python 2 会报错,Python 3 虽默认 UTF-8,但某些编辑器保存时可能用 GBK,造成运行时解码失败。
- 必须在文件第一行或第二行加编码声明:
# -*- coding: utf-8 -*-
- VS Code、PyCharm 默认以 UTF-8 保存,但右下角状态栏要确认显示的是
UTF-8,不是GBK或ISO-8859-1 - 用
file -i your_script.py(Linux/macOS)或xxd -l 20 your_script.py查看实际 BOM 或编码字节
写入文件时没指定 encoding 参数
open("out.txt", "w").write("你好") 在 Windows 上可能因默认编码是 cp1252 或 gbk 导致写入失败或乱码。
- 显式指定编码是必须的:
with open("out.txt", "w", encoding="utf-8") as f: f.write("你好") - 不要依赖
sys.getdefaultencoding()—— 它返回'utf-8',但不控制文件 I/O 编码 - 若需兼容 Windows 记事本(它依赖 BOM 识别 UTF-8),可写为
encoding="utf-8-sig"
print() 输出到非终端环境(如日志、管道、Web 响应)
在 Flask、Django 或 subprocess 调用中,print() 可能被重定向到无编码信息的 buffer,或接收方(如 nginx、logrotate)按错误编码解析。
- Web 框架中优先用响应对象设置 charset:
return Response("你好", content_type="text/plain; charset=utf-8") - 子进程捕获输出时,用
subprocess.run(..., encoding="utf-8", stdout=subprocess.PIPE) - 日志模块要配置
handlers的encoding="utf-8",否则FileHandler可能用系统默认编码写入
真正卡住人的往往不是“怎么让 Python 显示中文”,而是某个环节静默用了错误编码——比如 IDE 终端设对了,但你用 python script.py > out.log 重定向时,cmd 自己又切回 GBK;或者文件写了 UTF-8,但双击用记事本打开没 BOM 就当 ANSI 解析。盯住每个数据出口的 encoding 显式声明,比全局改系统设置更可靠。
到这里,我们也就讲完了《Python中文输出设置方法详解》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
310 收藏
-
126 收藏
-
284 收藏
-
117 收藏
-
236 收藏
-
266 收藏
-
263 收藏
-
481 收藏
-
430 收藏
-
279 收藏
-
268 收藏
-
498 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习