栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

truncate鍑芥暟python_python f.truncate?

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

truncate鍑芥暟python_python f.truncate?

之前练习truncate时,一直报错。想不通缘由。

f = open('./a.txt','r+',encoding='utf-8')
a = f.read()
f.seek(0,0)
f.truncate(5)
b = f.read()
print(b)
#a.txt内容:我就试一下我就是文档

Traceback (most recent call last):
  File "D:pyproject文件操作与模块文件文件的定位读取.py", line 41, in
    b = f.read()
  File "D:pypythonlibcodecs.py", line 322, in decode
    (result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode bytes in position 3-4: unexpected end of data
百度之后还是没有答案,只是试了一下此博客的代码段能正常运行:

python中的truncate()方法_yandajiangjun的博客-CSDN博客_python truncate

然后才想起来在UTF-8编码中:一个中文等于三个字节,中文标点占三个字节。 一个英文字符等于一个字节,英文标点占一个字节。

而truncate的size对应的是字节而不是字符,在中文文档中跳转非3的倍数字节相当于一个中文的一部分,自然会报错。

f = open('./a.txt','r+',encoding='utf-8')
a = f.read()
f.seek(0,0)
f.truncate(3)
b = f.read()
print(b)

所以注意打开中文文档时跳转字节数能够对应上字符就可以了。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/783239.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号