令人不悦的Error-UnicodeEncodeError: ‘gbk’ codec can’t encode character u’\u200b’的解决方法

本文主要是介绍令人不悦的Error-UnicodeEncodeError: ‘gbk’ codec can’t encode character u’\u200b’的解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简单记录一下今天写代码遇到的一个错误,并附上我的解决方法。

大家好,我是老表,这个系列会记录我在编程中遇到的一些问题和解决方法,将直接以遇到的报错作为标题,这样更能方便其他学习者在浏览器中搜索到问题解决方法,也欢迎大家在评论、留言区多交流,谈谈自己的理解或者问题。

比如令人不悦的–requests.exceptions.ProxyError就是一个很好的示范。

问题

UnicodeEncodeError: ‘gbk’ codec can’t encode character u’\u200b’

【2021.8.27更新】感谢网友靠谱的人在本文评论区提供的更好的解决方法:
在代码开头加上

import sys,io
sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='gb18030')

我最开始解决方法

首先,这个错误是指Unicode编码不能被解析成GBK编码(具体原因是:我的字符串里的这个Unicode编码已经超出了gbk编码的范围)
我第一时间想到的方法是把“\u200b”这个字符从我的字符串里移除,结果失败,查了一下,说有可能是排版自带的格式实际是不可见字符,所以无法移除(吐血.jpg),的确也是,我是通过爬虫拿下来的数据。
第二种方法,网络方法

# 方法一:直接忽略gbk编码,吐血.jpg,我就是要保存成gbk格式,无用
gbkTypeStr = unicodeTypeStr.encode("GBK", ‘ignore’)
# 方法二:扩大gbk的编码范围到GB18030,失败
gb18030TypeStr = unicodeTypeStr.encode("GB18030")

走头无路,还得靠自己,,,扣脑阔,我的方法:

            if "\u200b" in content:print("我错了")print(content)data_list.append("有错误字符")else :data_list.append(content)

进行内容判断,如果“\u200b”在,就将内容替换成“有错误字符”,并在控制台打印“我错了”提示我出错地方,并打印出原内容(包含“\u200b”),方便后面直接对应更改。解决问题。

反思

当然我的这个方法绝对不是最好的方法,但对于我目前遇到的问题能够解决,并且比较简单易转换,所以我觉得这是个好办法。

不过很显然,这不是个聪明的办法,所以,解决问题不一定只有聪明的人可以,也不一定只有很高深的聪明的方法能解决问题,解决问题取决于你遇到问题的性质,数量级,以及你的思考,所以当大家遇到bug的时候记住:不要烦恼,静下心来百度谷歌测试,you can。

这篇关于令人不悦的Error-UnicodeEncodeError: ‘gbk’ codec can’t encode character u’\u200b’的解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/824741

相关文章

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac