1.打开文件,获得文件句柄并赋值给一个变量 2.经过句柄对文件进行操做 3.关闭文件 打开模式: r 模式,默认模式,文件不存在则报错 w 模式,文件不存在则建立,文件存在则覆盖 a 模式,文件不存在则建立,文件存在则不会覆盖,写内容会以追加的方式写(写日志文件的时候经常使用),追加模式是一种特殊的写模式 b(rb,wb,ab)模式:二进制模式,不用加encoding:utf-8bash
f=open('c.txt','rb') #只读模式打开c.txt文件,句柄为f
print(f.read()) #读取整个文档
print(f.read().decode())
f=open('d.txt','wb') #二进制只写方式打开d.txt
f.write('啦啦啦'.encode('utf-8'))
f.close()
复制代码
1.文件打开模式 文件句柄=open('文件路径',‘模式’) 打开文件时,须要指定文件路径和以什么方式打开文件。 打开文件的模式有: r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】 w,只写模式【不可读;不存在则建立;存在则清空内容】 x, 只写模式【不可读;不存在则建立,存在则报错】 a, 追加模式【可读; 不存在则建立;存在则只追加内容】 只读模式工具
f=open(r'c.txt',encoding='utf-8')
print('====>1',f.read())
print('====>2',f.read())
print(f.readable())
print(f.readline(),end='')
print(f.readline())
print("="*20)
print(f.read())
print(f.readlines())
f.close()
复制代码
写模式:文件不存在则建立,文件存在则覆盖原有的测试
f=open("new.py",'w',encoding='utf-8')
f.write('1111111111\n')
f.writelines(['2222\n','2222548\n','978646\n'])
f.close()
复制代码
追加模式:文件不存在则建立,文件存在不会覆盖,写内容是追加的方式写ui
f=open('new.py','a',encoding='utf-8')
f.write('nishishui\n')
f.writelines(['aa\n','bb\n'])
f.close()
复制代码
"+" 表示能够同时读写某个文件编码
r+, 读写【可读,可写】 w+,写读【可读,可写】 x+ ,写读【可读,可写】 a+, 写读【可读,可写】spa
"b"表示以==字节==的方式操做日志
rb 或 r+b wb 或 w+b xb 或 w+b ab 或 a+b ==注:以b方式打开时,读取到的内容是字节类型,写入时也须要提供字节类型,不能指定编码==code
练习,利用b模式,编写一个cp工具,要求以下: 既能够拷贝文本又能够拷贝视频,图片等文件视频
## 二进制读模式
f=open('1.jpg','rb')
data=f.read()
print(data)
## 二进制写模式
f=open('2.jpg','wb')
f.write(data)
print(data)
复制代码
写模式图片
with open('a.txt','w') as f:
  f.write('要写入的信息')
复制代码
拷贝操做
with open('a.txt','r') as rf,open('b.txt','w') as wf:
  data=read_f.read()
  write_f.write(data)
复制代码
import os
with open('a.txt','r',encoding='utf-8') as read_f,open('a.txt.swap','w',encoding='utf-8') as write_f:
for line in read_f:
write_f.write(line)
os.remove('a.txt')
os.rename('.a.txt.swap','a.txt')
复制代码
一: read(3): 1. 文件打开方式为文本模式时,表明读取3个字符 2. 文件打开方式为b模式时,表明读取3个字节 二: 其他的文件内光标移动都是以字节为单位如seek,tell,truncate ==注意:== 1. seek有三种移动方式0,1,2,其中1和2必须在b模式下进行,但不管哪一种模式,都是以bytes为单位移动的 seek控制光标的移动,是以文件开头做为参照的。 tell当前光标的位置 2. truncate是截断文件,截断必须是写模式,可是不能用w或w+等方式打开,由于那样直接清空文件了,因此truncate要在r+或a或a+等模式下测试效果
import time
with open('test.txt','rb') as f:
f.seek(0,2)
while True:
line=f.readline()
if line:
print(line.decode('utf-8'))
else:
time.sleep(0.2)
复制代码