第一步 排除文件打开方式错误:
r只读,r+读写,不创建 ###f.readline()是读取第一行,f.readlines()是读取全部并返回一个列表
w新建只写,w+新建读写,会将文件内容清零
(以w方式打开,不能读出。w+可读写)
**w+与r+区别:
r+:可读可写,若文件不存在,报错;w+: 可读可写,若文件不存在,创建
r+与a+区别:
1. <span style="background-color: rgb(255, 255, 255);">fd = open("1.txt",'w+')
2. fd.write('123')
3. fd = open("1.txt",'r+')
4. fd.write('456')
5. fd = open("1.txt",'a+')
6. fd.write('789')</span>
结果:456789
说明r+进行了覆盖写。
以a,a+的方式打开文件,附加方式打开
(a:附加写方式打开,不可读;a+: 附加读写方式打开)
以 'U' 标志打开文件, 所有的行分割符通过 Python 的输入方法(例#如 read*() ),返回时都会被替换为换行符\n. ('rU' 模式也支持 'rb' 选项) .
r和U要求文件必须存在
不可读的打开方式:w和a
若不存在会创建新文件的打开方式:a,a+,w,w+
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd=open(r'f:\mypython\test.py','w')<span style="white-space:pre"> </span>#只读方式打开,读取报错
2. >>> fd.read()
3. Traceback (most recent call last):
4. "<stdin>", line 1, in <module>
5. IOError: File not open for reading
6. >>> fd=open(r'f:\mypython\test.py','a')<span style="white-space:pre"> </span>#附加写方式打开,读取报错
7. >>> fd.read()
8. Traceback (most recent call last):
9. "<stdin>", line 1, in <module>
10. IOError: File not open for reading
11. >>></span></span></span>
2.正确读写方式打开,出现乱码
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd=open(r'f:\mypython\test.py','a+')
2. >>> fd.write('123')
3. >>> fd.read()
4. '\x02\xe0\xe9\xdc\x00\x00\x00\x00\x00\x00\...'<pre name="code" class="python">>>> fd.close()
5. </span></span>
close之前,手动打开文件,什么都没写入;close后,手动打开文件,乱码:123嚅?
原因分析:指针问题。open()以a+模式开启了一个附加读写模式的文件,由于是a,所以指针在文件末尾。此时如果做read(),则Python发现指针位置就是EOF,读取到空字符串。
在写入123之后,指针的位置是4,仍然是文件尾,文件在内存中是123[EOF]。
但看起来read()的时候,Python仍然去试图在磁盘的文件上,将指针从文件头向后跳3,再去读取到EOF为止。
也就是说,你实际上是跳过了该文件真正的EOF,为硬盘底层的数据做了一个dump,一直dump到了一个从前存盘文件的[EOF]为止。所以最后得到了一些根本不期待的随机乱字符,而不是编码问题造成的乱码。
解决方案:读取之前将指针重置为文件头(如果读取之后重置再读,无效)
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd=open(r'f:\mypython\test.py','a+')
2. >>> fd.seek(0)
3. >>> fd.read()
4. '123'<span style="white-space:pre"> </span>#顺利读出</span></span>
3.文件里有内容,却读出空字符
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd=open(r'f:\mypython\test.py','w+') #清空内容,重新写入
2. >>> fd.write('456')
3. >>> fd.flush()<span style="white-space:pre"> </span>#确定写入,此时文件内容为“456”
4. >>> fd.read()
5. ''<span style="white-space:pre"> </span>#读出空</span></span>
原因:同样是指针问题,写入后指针指向末尾[EOF],因此读出空
解决方案一、调用close后重新打开,指针位于开头。(r,r+,a+,U都可以,注意不要用w,w+,a打开)
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd.close()
2. >>> fd=open(r'f:\mypython\test.py','a+')
3. >>> fd.read()
4. '456'
5. >>> fd.close()
6. >>> fd=open(r'f:\mypython\test.py','r+')
7. >>> fd.read()
8. '456'<pre name="code" class="python">>>> fd.close()
9. >>> fd=open(r'f:\mypython\test.py','r')
10. >>> fd.read()
11. '456'
12. >>> fd.close()
13. >>> fd=open(r'f:\mypython\test.py','U')
14. >>> fd.read()
15. '456'</span></span>
解决方案二、调用seek指向开头
1. <span style="font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">>>> fd=open(r'f:\mypython\test.py','w+')
2. >>> fd.write('456')
3. >>> fd.seek(0)
4. >>> fd.read()
5. '456'</span></span>
seek函数
seek(offset[, whence]) ,offset是相对于某个位置的偏移量。位置由whence决定,默认whence=0,从开头起;whence=1,从当前位置算起;whence=2相对于文件末尾移动,通常offset取负值。