绝对路径:
1 f = open('seek','r',encoding='utf-8')2 print(f.tell())3 f.seek(10,0)#从起始位置开始4 print(f.tell())5 f.seek(3,0)6 print(f.tell())
运行结果: 0103Process finished with exit code 0
相对路径:
1 f = open('seek','rb')#以b方式打开 不能有encoding(冲突)2 print(f.tell())3 f.seek(10,1)4 print(f.tell())5 f.seek(3,1)#相对于106 print(f.tell())
运行结果:
01013Process finished with exit code 0
倒叙输出:
1 f = open('seek','rb')2 print(f.tell())3 f.seek(-5,2)#\r\n会被读出来 读取后面五个字节4 print(f.read())
建议循环文件的方式:
#循环文件的方式for i in file:#一次取一行,并且方式为要一行去一行 print(i)
seek应用:
1 #需求:读取日志文件最后一条记录2 第一种方式:【不推荐】3 f = open('日志文件','rb')4 data = f.readlines()#读取整个文件 作为列表 占用大量内存且无用5 print(data[-1].decode('utf-8'))
1 #大文件的最后一行读取方式(可应用于日志文件)【推荐】 2 f = open('seek','rb') 3 for i in f: 4 offs=-10#定义一个偏移量 大概每条记录的字节数 5 while True: 6 f.seek(offs,2)#每一次都seek10个 7 data = f.readlines() 8 if len(data)>1: 9 print('文件的最后一行是:%s'%(data[-1]).decode('utf-8'))10 break11 offs*=2