zoukankan      html  css  js  c++  java
  • python文件读写操作(r/r+/rb/w/w+/wb/a/a+/ab)

    一、常用

    ‘r’:只读。该文件必须已存在。

    ‘r+’:可读可写。该文件必须已存在,写为追加在文件内容末尾。

    ‘rb’:表示以二进制方式读取文件。该文件必须已存在。

    ‘w’:只写。打开即默认创建一个新文件,如果文件已存在,则覆盖写(即文件内原始数据会被新写入的数据清空覆盖)。

    ‘w+’:写读。打开创建新文件并写入数据,如果文件已存在,则覆盖写。

    ‘wb’:表示以二进制写方式打开,只能写文件, 如果文件不存在,创建该文件;如果文件已存在,则覆盖写。

    ‘a’:追加写。若打开的是已有文件则直接对已有文件操作,若打开文件不存在则创建新文件,只能执行写(追加在后面),不能读。

    ‘a+’:追加读写。打开文件方式与写入方式和'a'一样,但是可以读。需注意的是你若刚用‘a+’打开一个文件,一般不能直接读取,因为此时光标已经是文件末尾,除非你把光标移动到初始位置或任意非末尾的位置。(可使用seek() 方法解决这个问题,详细请见下文Model 8 示例)



             看完上面各个模式的释义,可能有的人会觉得一堆文字有些枯燥,我一开始也是觉得如此,but,看似那么多模式,无非是三大类:读r(read),写w(write),追加a(append)。

            当然,我会用尽可能精短的代码为大家解释,文件操作各个模式具体如何使用。请继续往下看。

    二、demo

    Model 1: r ---只读模式

    注意:test2.txt 必须文件是已存在的。顺便说一下字符编码。因为Windows操作系统默认字符编码为GBK,而Python默认Unicode.utf-8,如果不写“ encoding=‘utf-8' "就会报错。

    Model 2: r+ ---可读可写模式

    Model 3: rb ---以二进制方式读取文件

    Model 4: w ---只写模式
    Model 5: w+ ---写读模式
    
    
    
    
    Model 6: wb+ ---以二进制方式读写文件
    Model 7: a ---追加写模式



    Model 8: a+ ---追加读写模式

    三、拓展

        以下是文件操作中常用的一些方法:

    print(f.readline())    # 打印一行
    print(f.readline(5)) # 打印前5个字符
    print(f.tell()) # 打印当前指针位置
    print(f.read()) # 读完文件后,指针在最尾处
    f.seek(0) # 如要重头到尾再读,文件指针须先回到文件头(0-文件头,默认值; 1-当前位置; 2-文件尾)
    print(f.read()) # 重读文件
    print(f.encoding) # 打印当前使用的字符编码
    print(f.name) # 打印文件名
    print(f.flush()) # 刷新
    f.truncate() # 清空文件
    f.truncate(12) # 从头开始,第12个字符后截断并清除
    f.close() # 关闭文件

    四、补充一个面试题:
    题目:文本文件id-name.txt中以如下格式保存了学号和姓名信息,其中学号是唯一的,不会重复,学号的顺序无所谓。
    123,yang
    1234,dong
    ……
    现在来了一名新生,学号为654321,姓名为王五,请用python代码添加把新学生添加进txt文件名单。
    如果该学生已经存在,则用“王五”代替当前学号的姓名,学生人数不多,不用考虑代码的执行效率。
    个人追加问题:如果考虑代码执行效率?该怎么设计?

    附加本人半成品代码:没有考虑优化
    # 1. 读取文件内容
    with open("./tihuan.txt", "r") as f:
        f_r = f.read()
        old_content = f_r.split("\n")
        old_content2 = [item.split(",") for item in old_content]
    
    # 2. 获取新内容,将新内容切割得到id和date
    new_content = input("请输入新内容:")
    new_id = new_content.split(",")[0]
    new_data = new_content.split(",")[1]
    
    # 3.判断是否和文件中内容的ID重复,记录重复ID在old_content2的下表索引值 添加到列表中, 计算重复总数count
    replace_index = []
    count = 0
    for i in old_content2:
        if len(replace_index) <= len(old_content2):
            if new_id == i[0]:
                replace_index.append(count)
            count+=1
    
    # 4. 根据记录的重复索引下表列表长度 判断是 执行替换还是 追加操作
    if len(replace_index) == 0:
        print("没有重复内容,将新内容追加到文件末尾")
        with open("./tihuan.txt", "a") as f_a:
            f_a.write(new_content)
            f_a.close()
    else:
        print("文件中有{}个相同内容".format(len(replace_index)))
        for i in replace_index:
            old_content2[i][1] = new_data
    
        # 5. 新内容字符串拼接
        str_data = ""
        for i in old_content2:
            str_data += i[0] + "," + i[1] + "\n"
    
        # 6. 将新内容写入文件
        with open("./tihuan.txt", "w") as f_w:
            f_w.write(str_data)
            f_w.close()
  • 相关阅读:
    [算法说明]SAP HANA PAL 指数平滑算法说明 沧海
    [Step By Step]SAP HANA PAL演绎推理算法Lite Aprior实现LITEAPRIORIRULE 沧海
    [PAL规范]SAP HANA PAL K分值硬聚类算法KMeans编程规范KMEANS 沧海
    [Step By Step]SAP HANA PAL K分值硬聚类算法KMeans Validated实现案例VALIDATEKMEANS 沧海
    SAP HANA AFL插件库升级后之前生成的存储过程升级方法(PAL升级方法) 沧海
    [PAL规范]SAP HANA PAL单指数平滑编程规范 沧海
    [PAL规范]SAP HANA PAL演绎推理算法Lite Apriori编程规范LITEAPRIORIRULE 沧海
    [Step By Step]SAP HANA PAL K分值硬聚类算法KMeans实现KMEANS 沧海
    [Step By Step]SAP HANA PAL Time Series单指数平滑算法SINGLESMOOTH(Single Exponential Smoothing) 沧海
    [PAL规范]SAP HANA PAL K分值硬聚类算法KMeans Validated编程规范VALIDATEKMEANS 沧海
  • 原文地址:https://www.cnblogs.com/yblackd/p/12107261.html
Copyright © 2011-2022 走看看