目录
1.1 seek函数介绍
seek函数用于移动文件中指针位置和指定指针移动偏移量大小。
seek()函数格式为:
file. seek(offset[, whence])
offset是偏移量,可正可负,正数表示向后面移动offset位,负数表示向前面移动offset位;
whence有0,1,2三个参数,0表示将指针移动到文件开头,1表示将指针移动到当前位置,2表示将指针移动到文件结尾。
1.2 seek函数示例:
with open("字母表.txt","r") as f:
a = f.read()
# 读取文件中所有字符
print(a)
# 从第三位开始输出
f.seek(2,0)print(f.read()) # 从索引2开始输出
# 结果输出为
ABCDEFGHIJKLMN
CDEFGHIJKLMN
1.3 使用f.seek(2,1)时报错
在f.seek(2,1)时报错:
with open("字母表.txt","r") as f:
a = f.read()
# 读取文件中所有字符
print(a)
# 从第三位开始输出
f.seek(2,0)print(f.read()) # 从索引2开始输出
# 从头开始,指针从第三个字符位置开始
f.seek(3,0)
# 将指针从当前位置往后移动两个字符
f.seek(2,1)print(f.tell()) # 此时输出结果应为5print(f.read()) # 从索引为5开始输出
print(f.tell()) # 此时指针指向末尾
报错信息如下:
Traceback(most recent call last):
File "D:/a_user_file/pycharm/1_lianxi/2_seek_tell.py", line 13, in <module>
f.seek(2,1)
io.UnsupportedOperation: can't do nonzero cur-relative seeks
Process finished with exit code 1
出错原因:在选用读取文本时,seek()方法只有在文件开头(即参数whence为0时)进行偏移是被允许的。在当前所在位置(参数whence为1时)和文件末尾(参数whence为2时)时进行偏移是不被允许的。
修改后的代码:
with open("字母表.txt","rb+") as f:
a = f.read()
# 读取文件中所有字符
print(a)
# 从第三位开始输出
f.seek(2,0)print(f.read()) # 从索引2开始输出
# 从头开始,指针从第三个字符位置开始
f.seek(3,0)
# 将指针从当前位置往后移动两个字符
f.seek(2,1)print(f.tell()) # 此时输出结果应为5print(f.read()) # 从索引为5开始输出
print(f.tell()) # 此时指针指向末尾
# 输出的结果为:
b'ABCDEFGHIJKLMN'
b'CDEFGHIJKLMN'5
b'FGHIJKLMN'14
1.4 seek函数因为偏移量设置错误导致报错
seek函数在计算偏移量时,英文字符和标点占用一个字符,中文则占用了三个字符。如果文件中的信息包含中文,则偏移量设置不正确也会导致报错。
with open("1.txt","r+",encoding='utf-8') as f:
a = f.read()
# 读取文件中所有字符
print(a)
f.seek(3,0)print(f.read())
f.seek(2,0)# 此处会报错
print(f.read())
运行后的结果显示:
Traceback(most recent call last):
File "D:/a_user_file/pycharm/1_lianxi/2_seek_tell.py", line 10, in <module>print(f.read()) # 从索引2开始输出
File "D:\app_download\anaconda3_2.5.0\anaconda3\envs\tensorFlow\lib\codecs.py", line 321, in decode(result, consumed)= self._buffer_decode(data, self.errors, final)
UnicodeDecodeError:'utf-8' codec can't decode byte 0x91 in position 0: invalid start byte
我爱你python
爱你python
Process finished with exit code 1
2.1 tell函数
tell函数能够返回指针在文件中的位置。
举例:
with open("字母表.txt","r") as f:
a=f.read()
# 读取文件中所有字符
print(a)
#从第三位开始输出
f.seek(2)print(f.tell()) #指针位于第二个字符
print(f.read())# 从索引2开始输出
# 从头开始,指针从第三个字符位置开始
f.seek(3,0)print(f.tell())# 输出结果为3print(f.read())# 从索引为3开始输出
print(f.tell())# 此时指针指向末尾
输出结果为:
ABCDEFGHIJKLMN
2
CDEFGHIJKLMN
3
DEFGHIJKLMN
14
版权归原作者 Dream_Bri 所有, 如有侵权,请联系我们删除。