7.8 文件操作

一。文件模式

  1.在文件的操作中,也有很多补充 的模式可使用

  1.r+,可读可写模式,在此模式中,操作权限时可读可写,这里的写与write模式不一样的是,不再清空文件内容,写的内容添加到文件的后面,而光标依然再读取的操作地方。

  2.w+,可写可读模式,此模式读写都可以,但和w一样会在写的时候会将文件原先的内容删除。

  3.a+,可追加可读可写模式,此模式读写都可以,是再原先追加的情况下增加读写权限。

  2.read()

  read()在使用过程中是可以传参数的,当没有参数时,自动默认读取所有文件内容,传入int类型的数字后,会根据数字大小读取相应的字符。

with open('text1','rt',encoding='utf-8') as f:
    res=f.read(4)
    print(res)
#输出结果>>>我叫mt

  这里并非是根据字节数进行读取。

  3.seek()

  一个英文字符占一个字节,一个中文字符占三个字节。

  而seek()函数在操作文本文件时是根据字节数。

  seek(offset,whence)

  offset:相对偏移量。光标的移动位数,在移动时是按照字节数进行移动。

  whence:有三个参数可选,分别代表三个模式:

  0,参照文件开头,t和b都可以使用

with open('text1','rt',encoding='utf-8') as f:
    f.seek(3,0)
    res=f.read(2)
    print(res)
#输出结果>>>叫m(我叫mt)

  seek在移动光标时根据字节数,所以移动三位就是移动一位中文字。

  1,参照光标所在的当前位置,此模式只适用于b模式

with open('text1','rb') as f:
    print(f.read(3))
    f.seek(3,1)
    res=f.read(2)
    print(res.decode())
#输出结果>>>b'\xe6\x88\x91'
#mt(我叫mt)

  2,参照光标文件的末尾,此模式只能在b模式下使用

with open('text1','rb') as f:
    f.read()
    f.seek(-3,2)
    res=f.read(3)
    print(res)
    print(str(res,encoding='utf-8'))
#输出结果>>>b'\xe4\xbd\xa0'
#你(我叫mt你你你)

  小总结:在普通文本文件操作r模式下,read(1)代表的是读取的是一个字符,无论是中文还是英文,在b模式下读取的也是,一个字符相当于一个字节。seek()函数中位移光标是按照字节移动,三个模式中0模式可以在任意情况下使用,1,2模式只能在b模式下使用。

  例子

  使用文件操作,当文本文件添加新内容时,将添加的内容显示出来

  首先定义添加内容的过程:

import time
res = time.strftime('%Y-%m-%d %X')
# print(res,type(res))
with open(r'test01.txt','a',encoding='utf-8') as f:
    f.write('%s 老板发了1个亿的工资\n'%res)

  在将指针移到文件末端,循环读取一行内容,查看其内容:

with open(r'test01.txt',mode='rt',encoding='utf-8') as f:
    f.read()
    while True:
        res=f.readline()
        if res:
            print('新增内容%s'%res)

  4.truncate(x)截断文件

  将x所标记的字节位之前的保留,其他内容全部删除。

with open(r'test01.txt','a',encoding='utf-8') as f:
    f.truncate(6)  # 接收的字节的长度 整型
    # 保留0~6字节数 后面的全部删除(截断)
#输出结果>>>我叫(我叫mt,我是无敌的)

  5.修改文件操作

  在修改文件操作中,一般有两种方式。

  1.(1)先将数据从硬盘读取到内存,

    (2)在内存中进行修改

      (3)将新的内容覆盖到旧的文件中

with open('test01.txt',mode='r',encoding='utf-8') as f:
    data=f.read()
with open('test01.txt',mode='w',encoding='utf-8') as f2:
    f2.write(data.replace("lzx",'yzy'))

  上代码中把‘lzx’替换成了’yzy‘,这种方式对内存的负担很大,在程序中,将文件的所有数据都保存在了data中,所以这个方法很耗内存。

  2.(1)创建一个新的文件

    (2)循环读取需要修改的文件,在内存中修改完后,将数据保存到新文件中

    (3)将老文件删除,新文件的名字改成老文件的名字

  为了完成这个程序,需要使用os包,中对文件名进行修改,

import os
with open('test01.txt',mode='rt',encoding='utf-8') as f,\
    open('test01.swap',mode='wt',encoding='utf-8') as f2:
    for i in f:
        if 'yzy' in i:
            f2.write(i.replace('yzy','lzx'))
        if 'yzy' not in i:
            f2.write(i)
os.remove('test01.txt')
os.rename('test01.swap','test01.txt')

 

posted on 2019-07-08 20:01  一只萌萌哒的提莫  阅读(139)  评论(0编辑  收藏  举报