打印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。然后重新运行你的脚本。
相关推荐
lichenyang4539 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen9 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒9 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
奇奇怪怪的10 小时前
Embedding 模型 10+ 横向评测
前端
陈广亮10 小时前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰10 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼10 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
子兮曰11 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
Hyyy12 小时前
Function Calling / Tool Use的原理和实现模式
前端·llm·ai编程