打印ascii码报错问题

1. 问题

python 复制代码
File "sdk/smart_decision.py", line 146, in <module>
print(f'text: {text}')
UnicodeEncodeError: 'ascii' codec can't encode characters in position 6-16: ordinal not in range(128)

2. 分析问题

你遇到的这个错误: UnicodeEncodeError: 'ascii' codec can't encode characters in position 6-16: ordinal not in range(128) 是因为你在 Python 3 中尝试打印一个包含 非 ASCII 字符 的字符串(如中文),但当前终端/控制台不支持 UTF-8 编码,或者没有正确设置输出编码。3.

3. 解决方案

python 复制代码
✅ 解决方案一:在打印前手动指定编码

你可以将 
print
 改为使用 
.encode('utf-8', errors='ignore')
 或者使用 try-except 捕获异常:


✅ 方法 1:忽略非 ASCII 字符

print(f'text: {text.encode("ascii", "ignore").decode("ascii")}')

✅ 方法 2:直接使用 UTF-8 编码处理输出

print(f'text: {text}'.encode(sys.stdout.encoding, errors='replace').decode(sys.stdout.encoding))


✅ 解决方案二:确保标准输出支持 UTF-8

你可以显式设置标准输出的编码方式为 UTF-8:


✅ 方法:在脚本开头添加以下代码

import sys
import io

sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')

将其放在你的模块导入之前,比如:


# -*- coding: utf-8 -*-
import sys
import io

sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')

ROOT_DIR = os.path.dirname(os.path.abspath(__file__))
sys.path.append(ROOT_DIR)

from src.template_parse import TemplateParser
from src.keywords_analysis import KeywordsAnalyzer


✅ 解决方案三:修改运行环境编码设置

如果你是在 Windows 上运行脚本,可以尝试用管理员权限打开命令提示符,并运行:


chcp 65001

这会将命令行编码切换为 UTF-8。然后重新运行你的脚本。
相关推荐
programhelp_几秒前
Google 2026 New Grad SDE VO 三轮面试详解 | 含Behavioral、Coding、Design
java·服务器·数据库
@PHARAOH4 分钟前
HOW - 构建一个轻量前后端一体服务
前端·微服务·服务端
驭渊的小故事5 分钟前
java中的进程的详细解析
java·开发语言
青梅橘子皮8 分钟前
Linux---开发工具(2)(makefile、进度条、git、gdb)
linux·运维·服务器
Mr_sst12 分钟前
Codex 部署、使用教程 & Vibe Coding 实战指南
java·ai·语言模型·chatgpt·ai编程
无限进步_15 分钟前
【C++】C++11的类功能增强与STL变化
java·前端·数据结构·c++·后端·算法
一只小小Java17 分钟前
Echarts单表多图实现
前端·javascript·echarts
剑神一笑25 分钟前
Linux less 命令深度解析:从源码看分页器的设计智慧
linux·运维·less
dunky26 分钟前
Spring AI 深度解析:把 LLM 抽象成 Spring Bean 的底层逻辑
前端
星栈27 分钟前
Rust WASM 文件上传全链路:从浏览器到 S3,一个字节都不能少
前端·前端框架·开源