python 文件读取(一)

背景

在项目开始阶段 写入基础数据是很正常的,经常和读写文件打交道这样就需要 对相关知识比较熟悉

读写文件 使用方式

一般是通过open文件来实现 上下文管理器来实现,打开和关闭文件
with open(“a.txt”, “r”, encoding=”utf-8”) as f:
pass

文件使用方式标识

‘r’:默认值,表示从文件读取数据。
’ w’:表示要向文件写入数据,并截断以前的内容
‘a’:表示要向文件写入数据,添加到当前内容尾部
‘r+’:表示对文件进行可读写操作(删除以前的所有数据)
‘r+a’:表示对文件可进行读写操作(添加到当前文件尾部)
‘b’:表示要读写二进制数据
r只读,r+读写,不创建
w新建只写,w+新建读写,二者都会将文件内容清零
(以w方式打开,不能读出。w+可读写)
**w+与r+区别:r+:可读可写,若文件不存在,报错;w+: 可读可写,若文件不存在,创建
r+与a+区别:

fd = open("1.txt",'w+')  
fd.write('123')  
fd = open("1.txt",'r+')  
fd.write('456')  
fd = open("1.txt",'a+')  
fd.write('789') 

结果:456789
说明r+进行了覆盖写。
以a,a+的方式打开文件,附加方式打开
(a:附加写方式打开,不可读;a+: 附加读写方式打开)
以 ‘U’ 标志打开文件, 所有的行分割符通过 Python 的输入方法(例#如 read*() ),返回时都会被替换为换行符\n. (‘rU’ 模式也支持 ‘rb’ 选项) .
r和U要求文件必须存在
不可读的打开方式:w和a
若不存在会创建新文件的打开方式:a,a+,w,w+

不可读的打开方式:w和a

若不存在会创建新文件的打开方式:a,a+,w,w+

>>> fd=open(r'f:\mypython\test.py','w')    #只读方式打开,读取报错  
>>> fd.read()  
Traceback (most recent call last):  
  File "<stdin>", line 1, in <module>  
IOError: File not open for reading  
>>> fd=open(r'f:\mypython\test.py','a')#附加写方式打开,读取报错  
>>> fd.read()  
Traceback (most recent call last):  
  File "<stdin>", line 1, in <module>  
IOError: File not open for reading  
>>></span></span></span>

2.正确读写方式打开,出现乱码

 fd=open(r'f:\mypython\test.py','a+')  
 fd.write('123')  
 fd.read()  
 fd.close() 

close之前,手动打开文件,什么都没写入;close后,手动打开文件,乱码:123嚅?
原因分析:指针问题。open()以a+模式开启了一个附加读写模式的文件,由于是a,所以指针在文件末尾。此时如果做read(),则Python发现指针位置就是EOF,读取到空字符串。

在写入123之后,指针的位置是4,仍然是文件尾,文件在内存中是123[EOF]。

但看起来read()的时候,Python仍然去试图在磁盘的文件上,将指针从文件头向后跳3,再去读取到EOF为止。

也就是说,你实际上是跳过了该文件真正的EOF,为硬盘底层的数据做了一个dump,一直dump到了一个从前存盘文件的[EOF]为止。所以最后得到了一些根本不期待的随机乱字符,而不是编码问题造成的乱码。

解决方案:读取之前将指针重置为文件头(如果读取之后重置再读,无效)

>>> fd=open(r'f:\mypython\test.py','a+')  
>>> fd.seek(0)  
>>> fd.read()  
'123'<span style="white-space:pre">           </span>#顺利读出</span></span> 

3.文件里有内容,却读出空字符

 fd=open(r'f:\mypython\test.py','w+') #清空内容,重新写入  
 fd.write('456')  
 fd.flush()<span style="white-space:pre">     </span>#确定写入,此时文件内容为“456”  
fd.read()  
'' #读出空  

原因:同样是指针问题,写入后指针指向末尾[EOF],因此读出空
解决方案一、调用close后重新打开,指针位于开头。(r,r+,a+,U都可以,注意不要用w,w+,a打开)

>>> fd.close()  
>>> fd=open(r'f:\mypython\test.py','a+')  
>>> fd.read()  
'456'  
>>> fd.close()  
>>> fd=open(r'f:\mypython\test.py','r+')  
>>> fd.read()  
'456'<pre name="code" class="python">>>> fd.close()  
>>> fd=open(r'f:\mypython\test.py','r')  
>>> fd.read()  
'456'  
>>> fd.close()  
>>> fd=open(r'f:\mypython\test.py','U')  
>>> fd.read()  
'456'  

解决方案二、调用seek指向开头

 fd=open(r'f:\mypython\test.py','w+')  
 fd.write('456')  
 fd.seek(0)  
fd.read()  
'456

seek函数

seek(offset[, whence]) ,offset是相对于某个位置的偏移量。位置由whence决定,默认whence=0,从开头起;whence=1,从当前位置算起;whence=2相对于文件末尾移动,通常offset取负值。

记得close()关闭

当我们写文件时,操作系统往往不会立刻把数据写入磁盘,而是放到内存缓存起来,空闲的时候再慢慢写入。只有调用close()方法时,操作系统才保证把没有写入的数据全部写入磁盘。忘记调用close()的后果是数据可能只写了一部分到磁盘,剩下的丢失了。所以,还是用with语句来得保险:

with open(‘/Users/michael/test.txt’, ‘w’) as f:
f.write(‘Hello, world!’)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值