1.文件读取的三部曲:打开—>操作---->关闭

  • 打开文件
    f = open(‘文件绝对路径’)
\"\"\"
r:
    -只读,不可写
    -文件不存在,会报错

w:
    -只可写,不可读
    -文件存在,清空原有文件内容重新写入
    -文件不存在,创建一个新的文件并写入

a:
    -追加,只可写,不能读
    -文件存在,不清空,追加在原有文件内容后
    -文件不存在,创建一个新的文件并写入

r+:
    -可读可写
    -文件不存在报错
    -指针指向位置无法读出
    -先读后写,写在最后,读完后,指针指在最后,所有写在最后
    -先写再读,写在开头,且覆盖掉对应指针位置,读时,无法读出写的内容(写在指针对应位置)
    -直接写,写在开头,且覆盖掉对应的指针位置
    -先读再写再读,写在最后,但无法读出所写内容

w+:
    -可读可写
    -文件不存在,创建一个为新文件
    -文件存在,清空文件内容

a+:
    -追加,可读可写
    -文件存在,不清空,追加在原有文件内容后
    -文件不存在,创建一个新的文件并写入

\"\"\"
  • 操作
    print(f.tell()) #告诉当前文件指针所在的位置
    content = f.read()
    print(content)
    print(f.tell())

    • 读操作
      print(f.read())

    • 写操作
      f.write(‘python’)

  • 关闭
    f.close()

如果读取图片,音频或视频(非纯文本文件),需要通过二进制的方式进行读取与写入

  • 读取文本文件
    r r+ w w+ a a+ == rt rt+ wt wt+ at at+
  • 读取二进制文件
    rb rb+ wb wb+ ab ab+
将f1写入f2
f1 = open(\'1111.jpg\', mode=\'rb\')   # 先读取二进制文件内容
content = f1.read()
f1.close()

f2 = open(\'hello.jpg\', mode=\'wb\')
f2.write(content)     # 写入要复制的文件读到的内容
f2.close()

2.文件的常用操作

默认情况下读取文件的所有内容,小的文件,直接用read读取即可
如果是一个大文件(文件大小>内存大小) readline()

print(f.read(3)) ##前三个

  • 每次读取一行内容
    print(f.readline())

  • 读取文件内容,返回一个列表,列表元素分贝为文件的行内容
    print(f.readlines())

  • 判断是否可读可写
    print(f.readable())
    print(f.writable())

  • 对于每一行,去掉后面的’\\n’ —(列表生成式 map())
    print([line.strip() for line in f.readlines()])
    print(list(map(lambda x:x.strip(),f.readlines())))

f = open(\'/tmp/passwd\',\'rb\')
f.write(\'hello\')          #从指针所在位置写入,写的就是字符串的内容
f.writelines([\'a\',\'b\'])   #将列表中的每个元素写入文件
f.writable()
指针的操作
print(f.tell())
print(\'1:\',f.read(3))
print(f.tell())

f.seek(0,2)     ##文件末尾
 \"\"\"
 seek:移动指针
     第一个参数:偏移量>0:代表向后移动 <0:代表前移动
     第二个参数:
         0:移动指针到文件开头
         1:当前位置
         2:移动指针到文件末尾
\"\"\"
print(f.tell())
f.close()

3.上下文管理器:打开文件,执行完with语句内容之后,自动关闭文件对象

with open(\'/home/kiosk/Desktop/mshh\') as f:
    print(\'with语句里面:\',f.closed)  ##返回False,文件未关
    print(f.read())

print(\'after with语句:\',f.closed)    ##返回True,文件已关

4.通过yeild实现文件的读取

# 一行一行的读取数据
def bylineread(fimename):
    with open(fimename) as f:
        line = f.readline()
        while line:
            yield line
            line = f.readline()

# read是一个生成器对象
read = bylineread(\'data.txt\')
print(read)
# 1.next读取生成器内容
print(next(read))
# print(next(read))

# 2.for
for item in read:
    print(item) 

# 文件对象是可以for循环遍历的
from collections import Iterable
f = open(\'data.txt\')
print(isinstance(f,Iterable))
for i,item in enumerate(f):
    if i == 10:
        break
    print(i,item)
收藏 打印