python文件操作

文件操作的基本流程:

1、打开文件f_read = open("filename",mode = 'r',encoding="utf-8") 

    打开一个文件并且将文件句柄赋值给变量f_read,模式可以有多种,如:

  • r,只读模式(默认)。

  • w,只写模式。【不可读;不存在则创建;存在则删除内容;】

  • a,追加模式。【可读;   不存在则创建;存在则只追加内容;】

"+" 表示可以同时读写某个文件

  • r+,可读写文件。【可读;可写;可追加】

  • w+,写读

  • a+,同a

"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)

  • rU

  • r+U

"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)

  • rb

  • wb

  • ab

    文件句柄解释:在文件I/O中,要从一个文件读取数据,应用程序首先要调用操作系统函数并传送文件名,并选一个到该文件的路径来打开文件。该函数取回一个顺序号,即文件句柄(file handle),该文件句柄对于打开的文件是唯一的识别依据。要从文件中读取一块数据,应用程序需要调用函数ReadFile,并将文件句柄在内存中的地址和要拷贝的字节数传送给操作系统。当完成任务后,再通过调用系统函数来关闭该文件。-----来自‘百度’

2、通过文件句柄f_read对文件进行操作

    read([5])  默认读取整个文件,加参数表示读取5个字节

    readline()   默认读取一行,再运行一次readline()则读取下一行

    readable()  判断文件是否可读,如果可读返回True,否则返回False

    readlines()  把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。

    write(str)  将str写到文件中,不会加换行符 

    writable()  判断文件是否可写,同readable

    writelines(seq)   把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。

     flush()  把缓冲区的内容写入硬盘

     tell()  以文件开头为原点,返回文件操作标记的当前位置

     seek(offset[,whence])  将文件的操作标记移动到offset的位置,whence=0时,表示从头开始,=1时表示以当前位置为原点,=2时表示以文件末尾为原点。需要注意:如果文件以a或者a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾

 

3、关闭文件

    f_read.close()  即可

    PS:一般用with open("filename",'r+',encoding="utf-8") as f_read:  句式打开文件,这样等操作完成后python解释器会自动的关闭文件

 

        以下自己实现了一个对文本文件的增、删、改、查的操作,小弟不才,实现的较为曲折,还请各位指出需要优化的地方

import osdef operation():              #提供给用户的选择    oper_dict = {'1':'find','2':'change','3':'add','4':'remove'}    for key in oper_dict:        print(key,oper_dict[key])    select = input("请选择操作:").strip()    if select == '1' or select == 'find':        find()    if select == '2' or select == 'change':        change()    if select == '3' or select == 'add':        add()    if select == '4' or select == 'remove':        remove()def find():    out_flag = True          #用来跳出外层循环的标志位    while out_flag:        flag = False        l = []        with open('haproxy.conf','r',encoding='utf-8') as f_read:     #以读的方式打开文件            choice = input("请输入要查找的URL:").strip()            for line in f_read:                          #遍历文件的每行并进行匹配                if line.startswith("backend") and choice in line:                    flag = True                    continue                if line.startswith("backend") and flag:                    break                if flag:                    l.append(line.strip())              #将匹配到的URL之中的记录存放到l中        for i in l:                                      #输入结果            print(i)        w = input("是否继续查询?y/n").strip()        if w == 'y' or w == 'Y' or w == 'yes':            continue        if w == 'n' or w == 'N' or w == 'no':            out_flag = False    # os.rename("haproxy.conf","haproxy.conf.bak")  #将原文件更名,并将修改后的文件重命名    # os.rename("test","haproxy.conf")              #为了便于演示,这两行均没有运行def change():    flag = False    l = []    with open('haproxy.conf', 'r', encoding='utf-8') as f_read,open('test','w',encoding='utf-8') as f_write:        choice = input("请输入要更改的记录所属的URL:").strip()        for line in f_read:                           #与查找功能一样            if line.startswith("backend") and choice in line:                flag = True                continue            if line.startswith("backend") and flag:                break            if flag:                l.append(line.strip())        count = 0        for i in l:            print(count,i)            count += 1        record = int(input("请输入要修改的记录编号:").strip())        new_record = input("请输入新记录:").strip()                         #将输入的新记录覆盖到之前查出的列表中        l[record] = new_record    sign = False    times = 0    with open('haproxy.conf', 'r', encoding='utf-8') as f_read, open('test', 'w', encoding='utf-8') as f_write:        for line in f_read:            if line.startswith("backend") and choice in line:                sign = True                f_write.write(line)                continue            if line.startswith("backend") and sign:                sign = False                f_write.write(line)                continue            if sign:                if times < len(l):                    f_write.write('\t\t'+l[times]+'\n')                                         #将修改后的列表以行的方式写到新文件中                    times += 1                continue            else:                f_write.write(line)    # os.rename("haproxy.conf","haproxy.conf.bak")    # os.rename("test","haproxy.conf")def add():    flag = False    l = []    with open('haproxy.conf', 'r', encoding='utf-8') as f_read, open('test', 'w', encoding='utf-8') as f_write:        choice = input("请输入要添加的记录所属的URL:").strip()        record = input("请输入要添加的记录:").strip()        for line in f_read:            if line.startswith("backend") and choice in line:                flag = True                f_write.write(line)                f_write.write('\t\t'+record+'\n')                                           #查询到需要添加的URL后,在下一行添加需要增加的行即可                continue            if line.startswith("backend") and flag:                flag = False                f_write.write(line)                continue            if flag:                f_write.write(line)                continue            else:                f_write.write(line)    # os.rename("haproxy.conf","haproxy.conf.bak")    # os.rename("test","haproxy.conf")def remove():    flag = False    l = []    with open('haproxy.conf', 'r', encoding='utf-8') as f_read, open('test', 'w', encoding='utf-8') as f_write:        choice = input("请输入要删除的记录所属的URL:").strip()        for line in f_read:            if line.startswith("backend") and choice in line:                flag = True                continue            if line.startswith("backend") and flag:                break            if flag:                l.append(line.strip())        count = 0        for i in l:            print(count, i)            count += 1        record = int(input("请输入要删除的记录编号:").strip())        l.pop(record)    sign = False    times = 0    with open('haproxy.conf', 'r', encoding='utf-8') as f_read, open('test', 'w', encoding='utf-8') as f_write:        for line in f_read:            if line.startswith("backend") and choice in line:                sign = True                f_write.write(line)                 #没有进行修改的行正常写入                continue            if line.startswith("backend") and sign:                sign = False                f_write.write(line)                 #没有进行修改的行正常写入                continue            if sign:                if times < len(l):                    f_write.write('\t\t' + l[times] + '\n')   #将删除后的列表写到新文件里                    times += 1                continue            else:                f_write.write(line)    # os.rename("haproxy.conf","haproxy.conf.bak")    # os.rename("test","haproxy.conf")operation()