• 五、文件处理


    一、文件操作

      方式一:

    f=open('a.txt','r',encoding='utf-8')
    data=f.read()
    f.close()

    #文件操作完成后,必须close

      方式二:

    #用with关键字打开文件,不需要再执行close

    with open('a.txt','r') as read_f,open('b.txt','w') as write_f: data=read_f.read() write_f.write(data)

      强调!!!

    f=open(...)是由操作系统打开文件,那么如果我们没有为open指定编码,那么操作系统会用自己的默认编码去打开文件,在windows下是gbk,在linux下是utf-8。 这样有可能会造成乱码,若要保证不乱码,文件以什么方式存的,就要以什么方式打开。

    二、打开文件的模式

      1. 文件是文本文件

        r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】(rt)

        w,只写模式【不可读;不存在则创建;存在则清空内容】(wt)

        a, 追加写模式【不可读;不存在则创建;存在则只追加内容】(at)

      2. 非文本文件,如视频

        rb wb ab

        "b"表示以字节的方式操作(而所有文件也都是以字节的形式存储的,使用这种模式无需考虑文本文件的字符编码、图片文件的jgp格式、视频文件的avi格式)

        注:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型,不能指定编码

      3.其他

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

        r+, 读写【可读,可写】

        w+,写读【可读,可写】

        a+, 写读【可读,可写】

    三、操作文件的方法

    f.read() #读取所有内容,光标移动到文件末尾
    f.readline() #读取一行内容,光标移动到第二行首部
    f.readlines() #读取每一行内容,存放于列表中
    
    f.write('1111
    222
    ') #针对文本模式的写,需要自己写换行符
    f.write('1111
    222
    '.encode('utf-8')) #针对b模式的写,需要自己写换行符
    f.writelines(['333
    ','444
    ']) #文件模式
    f.writelines([bytes('333
    ',encoding='utf-8'),'444
    '.encode('utf-8')]) #b模式
    f.readable() #文件是否可读
    f.writable() #文件是否可读
    f.closed #文件是否关闭
    f.encoding #如果文件打开模式为b,则没有该属性
    f.flush() #立刻将文件内容从内存刷到硬盘
    f.name

     四、文件光标移动

    f=open('c:\python34\aaa.txt','a+',encoding='utf_8')
    f.writelines('222
    333
    ')
    f.flush()
    f.seek(0)     #读取文件前,必须先确认此刻光标的位置  seek(0)相当于seek(0,0)从文件开头数,seek(0,1)表示从当前位置开始数,seek(0,2)表示从末尾开始数
    data=f.read()
    print(data)

    五、文件修改

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

        方式一:将硬盘存放的该文件的内容全部加载到内存,在内存中是可以修改的,修改完毕后,再由内存覆盖到硬盘

    import os
    with open('c:\python34\aaa.txt','r+',encoding='utf_8') as a,open('c:\python34\a11.txt','w+',encoding='utf_8') as b:
        data=a.read()
        data=data.replace('killall','debug')
        b.write(data)
    os.remove('c:\python34\aaa.txt')
    os.rename('c:\python34\a11.txt','c:\python34\aaa.txt')

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

    with open('c:\python34\aaa.txt','r+',encoding='utf_8') as a,open('c:\python34\a11.txt','w+',encoding='utf_8') as b:
        for line in a:
            line=line.replace('killall','debug')
            b.write(line)
    os.remove('c:\python34\aaa.txt')
    os.rename('c:\python34\a11.txt','c:\python34\aaa.txt')

     六、练习题

     1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数,求出本次购物花费的总钱数
      apple 10 3
      tesla 100000 1
      mac 3000 2
      lenovo 30000 3
      chicken 10 3

    with open('c:\python34\a.txt','r+',encoding='utf_8') as a:
        sum=0
        for data in a:
            data1=data.split()
            sum+=int(data1[1])*int(data1[2])
        print(sum)

    2.修改文件内容,把文件中的alex都替换成keven

    import os
    with open('c:\python34\a.txt','r+',encoding='utf_8') as a,open('c:\python34\a11.txt','w+',encoding='utf_8') as b:
        for data in a:
            data=data.replace('alex','Keven')
            b.write(data)
    os.remove('c:\python34\a.txt')
    os.rename('c:\python34\a11.txt','c:\python34\a.txt')
  • 相关阅读:
    Java中的char究竟能存中文吗?
    AOP通过反射获取自定义注解
    烂翻译系列之面向.NET开发人员的Dapr——Actors构建块
    烂翻译系列之面向.NET开发人员的Dapr——目录
    烂翻译系列之面向.NET开发人员的Dapr——前言
    烂翻译系列之面向.NET开发人员的Dapr——分布式世界
    烂翻译系列之面向.NET开发人员的Dapr——俯瞰Dapr
    烂翻译系列之面向.NET开发人员的Dapr——入门
    烂翻译系列之面向.NET开发人员的Dapr——总结和前景
    烂翻译系列之面向.NET开发人员的Dapr——机密
  • 原文地址:https://www.cnblogs.com/haoy/p/10285895.html
Copyright © 2020-2023  润新知