1)打开文件
1、关于open 模式:
r 以读方式打开, f=open(r"C:\Users\readme.txt","r")
w 以写方式打开, 如果文件存在则会清洗掉原文件的内容,然后把写的东西写进新文件
f=open(r"C:\Users\readme.txt","w") #那么原来readme.txt的文件的内容将会被清洗掉
f.wirte("i am very good") #那么文件的原内容就会被清洗掉,现在readme.txt的内容只有i am very good 这句话
a 以追加模式打开 (从 EOF 开始, 必要时创建新文件)
>>>f=open(r"C:\Users\readme1.txt","a") >>> f.write("i will try my best to beyond myself") 35 #这个是py3.5.1中会返回写入的句子的总的字节数
r+ 以读写模式打开
1 f=open(r"C:\Users\readme1.txt","r+",encoding='utf-8') 2 r=f.tell() #返回0,说明指针一开始在文章的开头
3 print(r)
4
5 content=f.read()
6 print(content)
7 #i want to be very execellent
8 st to beyond myselfi want to be very execellent
9 ok,i want to be very execellent
10 以上是读取到的文件的全部内容
11 r=f.tell() #返回112 ,就是在文件的末尾,因为在read之后,指针自动跳到最后去
12 print(r)
13 content1=f.readline()
14 #返回112,指针已经在最后了,向后读没有内容 content1为空
15 print(content1)
16 r=f.tell()
17 print(r)
18 w=f.write("ok,i want to be very execellent"+ "\n")
19 r1=f.tell()
20 print(r1) #返回145,就是写入ok,i want to be very execellent之后,多了33个字节,就是这个字符串的长度
View Code
w+ 以读写模式打开 (参见 w )
1 f=open(r"C:\Users\readme1.txt","w+",encoding='utf-8') 2 r=f.tell()
3 print(r) #返回0,在文章的最开头
4 content=f.read()
5 print(content)
6 r=f.tell()
7 print(r) #返回0,w+模式打开的话,文件内容被清空,所以其实read没有读到任何内容
8 content1=f.readline()
9 print(content1)
10 r=f.tell()
11 print(r) #跟以上一样
12 w=f.write("ok,i want to be very execellent"+ "\n")
13 r1=f.tell()
14 print(r1) #返回33,就是最后写入的字符串的字节长度
View Code
a+ 以读写模式打开 (参见 a )
1 f=open(r"C:\Users\readme1.txt","a+",encoding='utf-8') 2 r=f.tell()
3 print(r) # 返回33,以a+的方式打开的话指针跳到文件最后,文件原来长度是33,所以返回33
4 content=f.read()
5 print(content)
6 r=f.tell() #返回33,以a+的方式打开的话指针跳到文件最后,文件原来长度是33, read方法读取完后指针跳到最后,所以返回33
7
8 w=f.write("ok,i want to be very execellent"+ "\n")
9 r1=f.tell()
10 print(r1) #返回66,写入字符串后,指针由原来的33变成33+33,即为66
View Code
rb 以二进制读模式打开
wb 以二进制写模式打开 (参见 w )
ab 以二进制追加模式打开 (参见 a )
rb+ 以二进制读写模式打开 (参见 r+ )
wb+ 以二进制读写模式打开 (参见 w+ )
ab+ 以二进制读写模式打开 (参见 a+ )
2、withopen模式,用 with open(文件路径,模式,编码格式) as 文件名:这种方法最后不用自己关闭文件,python会帮你自动关闭文件,用这种模式可以同时打开两个文件 一个读取,一个写进
>>> with open(r"C:\Users\readme.txt","r") as f1,open(r"C:\Users\readme1.txt","w") as f2:
for line in f1:
f2.write(line)
这段代码操作之后相应的文件夹下就多了一个readme1.txt的文件,内容与readme.txt一模一样
2)关闭文件
close() 函数是专门用来关闭已打开文件的,其语法格式也很简单,如下所示:
file.close()
其中,file 表示已打开的文件对象。
读者可能一直存在这样的疑问,即 使用 open() 函数打开的文件,在操作完成之后,一定要调用 close() 函数将其关闭吗?答案是肯定的。文件在打开并操作完成之后,就应该及时关闭,否则程序的运行可能出现问题。
举个例子,分析如下代码:
1. import os
2. f = open("my_file.txt",'w')
3. #...
4. os.remove("my_file.txt")
代码中,我们引入了 os 模块,调用了该模块中的 remove() 函数,该函数的功能是删除指定的文件。但是,如果运行此程序,Python 解释器会报如下错误:
Traceback (most recent call last):
...
PermissionError: [WinError 32] 另一个程序正在使用此文件,进程无法访问。: 'my_file.txt'
显然,由于我们使用了 open() 函数打开了 my_file.txt 文件,但没有及时关闭,直接导致后续的 remove() 函数运行出现错误。因此,正确的程序应该是这样的:
1. import os
2. f = open("my_file.txt",'w')
3. f.close()
4. #...
5. os.remove("my_file.txt")
当确定 my_file.txt 文件可以被删除时,再次运行程序,可以发现该文件已经被成功删除了。
再举个例子,如果我们不调用 close() 函数关闭已打开的文件,确定不影响读取文件的操作,但会导致 write() 或者 writeline() 函数向文件中写数据时,写入失败。例如:
1. f = open("my_file.txt", 'w')
2. f.write("C:\Users\")
程序执行后,虽然 Python 解释器不报错,但打开 my_file.txt 文件会发现,根本没有写入成功。这是因为,在向以文本格式(而不是二进制格式)打开的文件中写入数据时,Python 出于效率的考虑,会先将数据临时存储到缓冲区中,只有使用 close() 函数关闭文件时,才会将缓冲区中的数据真正写入文件中。
因此,在上面程序的最后添加如下代码:
1. f.close()
再次运行程序,就会看到"C:\Users\"成功写入到了 a.txt 文件。
当然在某些实际场景中,我们可能需要在将数据成功写入到文件中,但并不想关闭文件。这也是可以实现的,调用 flush() 函数即可,例如:
1. f = open("my_file.txt", 'w')
2. f.write("C:\Users\")
3. f.flush()
打开 my_file.txt 文件,会发现已经向文件中成功写入了字符串"C:\Users\"