Python 中关于文件操作的注意事项

发布时间:2019-05-26 22:22:38编辑:auto阅读(1879)

    1. 文件操作

      #打开文件
      f = open('要打开的文件路径',mode = 'r/w/a', encoding = '文件原来写入时的编码')
      
      #操作
      data = f.read()  #读取
      f.write('要写入的内容')
      
      #关闭文件
      f.close()
      #用于文字写入
      f = open('s.txt',mode = 'w', encoding = 'utf-8')
      f.write('你好')
      #上述代码进行了两步转化
      #  1.根据utf-8将文本转换成二进制
      #  2.将二进制写入到文件中
      f.close()
      
      #用于图片/视频/音频/未知编码的情况
      f = open('s.txt', mode = 'wb')
      #  1.将要写入的字符转变为二进制
      data = '我好困'
      content = data.encode('utf-8')  #将字符串按照utf-8编码转换成二进制
      #  2.将二进制写入到文件中
      f.write(content)  #wb打开文件,则write传入的是二进制
      f.close()
      • 模式

        • r / w / a【只读写字符串】

        • r+ / w+ / a+ 【可读写字符串】

        • rb / wb / ab【只读只写二进制】

          • 字符串转换”二进制“:

            v = '你好'
            data = v.encode('utf-8')
          • 二进制转为字符串

            v =  b'\xe6\x88\x91\xe5\xa5\xbd\xe5\x9b\xb0'
            data = decode('utf-8')
        • r+b / w+b / a+b 【可读可写二进制】

    2. with open() as f: 方法

      • 此种方法可以不用在文件操作后,写关闭文件代码f.close()。代码执行完毕后,自动关闭。
      #如果文件过大,可以一边读一边写。可用一行代码实现打开两个文件:
      keys = ['苍老师','小泽老师','alex']
      with open('a1.txt',mode='r',encoding='utf-8') as f1,\
          open('a2.txt',mode='w',encoding='utf-8') as f2:
              for i in f1:#i为字符串
                  for key in keys:
                      i = i.replace(key,'***')
                  f2.write(i)

    4.关于readline(),readlines(),for i in file: 之间的区别

    '''
    有a2.txt文件,内容如下:
    轻轻地我走了,正如我轻轻地来
    我挥一挥衣袖,不带走一片云彩
    '''
    # 1.readline()
    with open('a2.txt',mode='r',encoding='utf-8') as f:
        a = f.readline()
        print(a)
    # readline()方法的结果为:“轻轻地我走了,正如我轻轻地来”
    # readline()方法只读一行,()中可以填int,表示读到第x个字符为止。
    
    
    # 2.readlines()
    with open('a2.txt',mode='r',encoding='utf-8') as f:
        a = f.readlines()
        print(a)# 结果:['轻轻地我走了,正如我轻轻地来\n', '我挥一挥衣袖,不带走一片云彩\n']
    # readlines()方法是将文本逐行读取,并且添加到列表中,如果有换行,也会将换行符加入到列表中。
    #要去掉换行符,可用下面代码:
    with open('a2.txt',mode='r',encoding='utf-8') as f:
        a = f.readlines()
        li = []# 新建一个空列表
        for i in a:
            li.append(i.strip())# 利用strip()将每一行的换行符去掉,并追加到列表li中
        print(li)
    
        
        
    # 3.for i in f:方法
    # 一行一行读
    with open('a2.txt',mode='r',encoding='utf-8') as f:
        for i in f:
            print(i)
    # 结果为:
    '''
    轻轻地我走了,正如我轻轻地来
    
    我挥一挥衣袖,不带走一片云彩
    '''
    # 会有空行,所以应该这样写:
    with open('a2.txt',mode='r',encoding='utf-8') as f:
        for i in f:
            print(i.strip())
    1. 关于mode = "r" 或 "rb" 模式下,read()方法的不同
    # mode = 'r'
        read(3) # 读取三个字符
    # mode = 'rb'
        read(3) # 读取三个字节

    6.练习题

    '''
    有一个100G的文件a.txt,检测文件中是否有关键字 keys = ['苍老师','小泽老师','Alex'],如果有则替换成***,并写入另一个文件b.txt中。
    '''
    with open('a.txt',mode='r',encoding='utf-8') as f1,\
    with open('b.txt',mode='w',encoding='utf-8') as f2:
        for i in f1:
            i = i.strip()
            for key in keys:
                i = i.replace(key,'***')
                f2.write(i)

关键字