欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-21 20:42:01
1. 文件操作 模式 r / w / a【只读写字符串】 r+ / w+ / a+ 【可读写字符串】 rb / wb / ab【只读只写二进制】 字符串转换”二进制“: 二进制转为字符串 r+b / w+b / a+b 【可读可写二进制】 2. with open() as f: 方法 此种方法可以 ......
  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)