返回顶部
首页 > 资讯 > 后端开发 > Python >Python中,关于读取文件编码解码的问
  • 427
分享到

Python中,关于读取文件编码解码的问

文件Python 2023-01-31 01:01:08 427人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

UnicodeDecodeError: 'gbk' codec can't decode byte 0xb1 in position 94: illegal multibyte sequence 有时候用o

UnicodeDecodeError: 'gbk' codec can't decode byte 0xb1 in position 94: illegal multibyte sequence

            有时候用open()方法打开文件读取文件的时候会出现这个问题:‘GBK’编×××无法解码94号位置的字节0xb1:非法多字节序列。错误信息提示了使用“GBK”解码。
            1.分析
            PyCharm自动使用的是‘UTF-8’编码,好像没有什么问题,为什么会出现这个错误呢。结果查了下open()函数的注解,里面又这么一段话:
             encoding is the name of the encoding used to decode or encode the  file. This should only be used in text mode. *The default encoding is platfORM dependent*, but any encoding supported by python can be  passed.  See the codecs module for the list of supported encodings.
                 The default encoding is platform dependent:默认编码方式取决于平台。这也就不奇怪会用‘GBK’编码了,平台不一样,编码方式不一样,所以读取的时候回出现错误。
            2.解决方法
                    # 1.以byte读取,并以‘utf-8’解码
                    # fp = open(filename, 'rb')
                    # content = fp.read()
                    # self.content = content.decode('utf-8')
                    # fp.close()
                    # 2.在打开文件时指定编码方式
                    fp = open(filename, encoding='utf-8')
                    content = fp.read()
                    self.content = content
                    fp.close()

                    如有不同见解,欢迎分享。

--结束END--

本文标题: Python中,关于读取文件编码解码的问

本文链接: https://lsjlt.com/news/183102.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作