1.I/O操作:
I/O(Input/Output)也就是Stream(流)的输入和输出。这里的输入和输出是相对于内存来说的,Input Stream(输入流)是指数据从外(磁盘、网络)流进内存,Output Stream是数据从内存流出到外面(磁盘、网络)。程序运行时,数据都是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方(通常是磁盘、网络操作)就需要IO接口。
2.文件读写的操作步骤:
1) 打开文件,获取文件描述符
2) 操作文件描述符(读/写)
3) 关闭文件
3.打开文件模式:
t 文本模式 (默认)。
x 写模式,新建一个文件,如果该文件已存在则会报错。
b 二进制模式。
+ 打开一个文件进行更新(可读可写)。
U 通用换行模式(Python 3 不支持)。
r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。
r+ 打开一个文件用于读写。文件指针将会放在文件的开头。
rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。
w 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
w+ 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
a 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
注:默认为文本模式,如果要以二进制模式打开,加上 b。
4.文件打开方法:
1).使用python内置的open函数 2).使用with语句
方法1:python内置open函数
lg:
f=open('C:/test.txt','r')
f.close()
注意:
1.如果打开的文件test.txt不存在则会报IOError;
2.使用python内置open函数打开的话必须要使用close()将打开的文件关掉;
方法2:with语句
lg:
with open('C:/test.txt','r') as f
注意:
1.如果打开的文件test.txt不存在则会报IOError;
2.因为with语句会自动调用close()方法,所以不需要使用close()方法关掉文件;
5.文件读写定位操作
读:
(1) f.read(size)
如果没有size即f.read()一次性读取文件全部内容,返回类型str;如果有size即f.read(50)读取最多的字节内容;
(2) f.readline() 每次读取一行内容,返回类型str
(3) f.readlines() 一次读取所有内容并按行返回list
总结:
文件很小,可一次性读取,文件较大,超过内存大小,内容爆掉
文件过大,可用f.read(size),x为每次最多读取size字节的内容
如果是配置文件,调用 readlines()最方便
写:
f.write() 将字符串写入文件,如果写入结束,需要在字符串后面加上"\n"
f.writelines(sequence) 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
定位:f.seek(offset,from_what) f.seek(2,0)读取位置向后移动2个字符
from_what值为文件的开始位置,可以省略;offset为偏移量
当前定位:f.tell() 返回当前文件位置
6.文件读写语法规则:
open(file,mode='r',buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
file:必需,要打开的文件路径
mode:可选,文件打开模式
buffering:设置缓冲
encoding:一般使用utf-8
errors:报错级别
newline:区分换行符
closefd:传入的file参数类型
width:with open(filename,mode='r',encoding='utf-8') as f:
7.文件读写实例:
#coding:utf-8
def open_file1(filename):
# 读文件
f = open(filename,'r',encoding='utf-8')
msg = f.read(100)
print(msg)
# 写文件
f1 = open('test1.txt','w',encoding='utf-8')
f1.write(msg)
f.close()
f1.close()
open_file1('text.txt')
def open_file2(filename):
# 读文件
f = open(filename,'r',encoding='utf-8')
msg = f.read()
print(msg)
# 写文件
f1 = open('test1.txt', 'w', encoding='utf-8')
f1.write(msg)
f.close()
f1.close()
open_file2('text.txt')
def open_file3(filename):
# 读文件
f = open(filename,'r',encoding='utf-8')
while True:
msg = f.readline()
print(msg)
# 写文件
f1 = open('test1.txt', 'a+', encoding='utf-8')
f1.write(msg)
#判断文件读完
if not msg:
f.close()
break
f.close()
f1.close()
open_file3('text.txt')
def open_file4(filename):
#读文件
f = open(filename,'r',encoding='utf-8')
msg = f.readlines()
print(msg)
#写文件
for info in msg:
f1 = open('test1.txt', 'a+', encoding='utf-8')
f1.write(info)
f1.close()
f.close()
open_file4('text.txt')
def open_file1_1(filename):
#读文件
with open(filename,'r',encoding='utf-8') as f:
msg = f.read(100)
print(msg)
#写文件
with open('test1.txt','a+',encoding='utf-8') as f1:
f1.write(msg)
open_file1_1('text.txt')
def open_file2_1(filename):
#读文件
with open(filename,'r',encoding='utf-8') as f:
msg = f.read()
print(msg)
#写文件
with open('test1.txt','a+',encoding='utf-8') as f1:
f1.write(msg)
open_file2_1('text.txt')
def open_file3_1(filename):
#读文件
with open(filename,'r',encoding='utf-8') as f:
while True:
msg = f.readline()
print(msg)
if not msg:
break
#写文件
with open('test1.txt','a',encoding='utf-8') as f1:
f1.write(msg)
open_file3_1('text.txt')
def open_file4_1(filename):
# 读文件
with open(filename,'r',encoding='utf-8') as f:
msg = f.readlines()
print(msg)
# 写文件
for info in msg:
with open('test1.txt', 'a', encoding='utf-8') as f1:
f1.write(info)
open_file4_1('text.txt')