zoukankan      html  css  js  c++  java
  • 文件修改的两种方式

    文件修改的两种方式

    文件的数据是存放于硬盘上的,因而只存在覆盖、不存在修改这么一说,我们平时看到的修改文件,都是模拟出来的效果,具体的说有两种实现方式。

    一、方式一

    将硬盘存放的该文件的内容全部加载到内存,在内存中是可以修改的,修改完毕后,再由内存覆盖到硬盘(word,vim,nodpad++等编辑器)。

    import os
    with open('info.txt', 'r', encoding='utf-8') as fr,
         open('info_test.txt', 'w', encoding='utf-8') as fw:
    
        data = fr.read()
        data = data.replace('da', 'sab')
    
        fw.write(data)
    
    os.remove('info.txt')
    os.rename('info_test.txt', 'info.txt')
    

    二、方式二

    将硬盘存放的该文件的内容一行一行地读入内存,修改完毕就写入新文件,最后用新文件覆盖源文件。

    with open('info.txt', 'r', encoding='utf8') as fr,
         open('info_test.txt', 'w', encoding='utf8') as fw:
        # 逐行读取文件
        for data in fr:
            data = data.replace('da', 'dsb')
            fw.write(data)
    
    os.remove('info.txt')
    os.rename('info_test.txt', 'info.txt')
    

    总而言之,修改文件内容的思路为:以读的方式打开原文件,以写的方式打开一个新的文件,把原文件的内容进行修改,然后写入新文件,之后利用os模块的方法,把原文件删除,重命名新文件为原文件名,达到以假乱真的目的。

    在当下的阶段,必将由程序员来主导,甚至比以往更甚。
  • 相关阅读:
    关于C#中timer类 (转)
    AutoResetEvent (转)
    给韬哥的回复
    sql中的case when 的用法涉及到大于小于号
    vba中获取当前日期
    vba中的小技巧
    sql server2000中的两个整数相除保留十位小数
    vba中新建文件,关闭文件,锁屏,覆盖同名文件
    无法切换到google.com的解决办法
    mysql 常用命令
  • 原文地址:https://www.cnblogs.com/randysun/p/12238514.html
Copyright © 2011-2022 走看看