本文实例讲述了Python文件打开方式。分享给大家供大家参考,具体如下:
第一步 排除文件打开方式错误:
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+
>>> 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 >>>
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'#顺利读出
3.文件里有内容,却读出空字符
>>> fd=open(r'f:\mypython\test.py','w+') #清空内容,重新写入 >>> fd.write('456') >>> fd.flush()#确定写入,此时文件内容为“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' >>> 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取负值。
4. 记得close()关闭
当我们写文件时,操作系统往往不会立刻把数据写入磁盘,而是放到内存缓存起来,空闲的时候再慢慢写入。只有调用close()方法时,操作系统才保证把没有写入的数据全部写入磁盘。忘记调用close()的后果是数据可能只写了一部分到磁盘,剩下的丢失了。所以,还是用with语句来得保险:
with open('/Users/michael/test.txt', 'w') as f: f.write('Hello, world!')
看评论:对于'r+'来说,如果先读取了内容,再写入的话就变成了追加的模式,如果直接写入内容,就是覆盖了
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python文件与目录操作技巧汇总》、《Python文本文件操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
问题内容: 在内置的蟒蛇开放的功能,是个什么模式之间准确的区别? 特别是,文档暗示所有这些都将允许写入文件,并表示它打开文件专门用于“,但未定义这些术语的含义。 问题答案: 打开模式与标准库功能完全相同。 手册页对它们的定义如下:
问题内容: 我试着和打开文件和读取和写入,但“R +”和“A +”都是追加海峡到文件的末尾。 那么,和之间有什么区别? 加: 我发现了原因: 我已经阅读了文件对象,却忘记了seek(0)来将位置设置为开始 问题答案: Python几乎以与C中相同的方式打开文件: 开放供阅读和写作。流位于文件的开头。 打开以进行读取和追加(在文件末尾写入)。 如果文件不存在,则创建该文件。 读取的初始文件位置在文件
本文向大家介绍Python文件读写w+和r+区别解析,包括了Python文件读写w+和r+区别解析的使用技巧和注意事项,需要的朋友参考一下 其实r 是只读,只能读不能写,这是很明确的,但是r+是可读写,变成r+后还没太明白到底加了什么,还是照样写不了,有没有这样的体验呢,如下代码,只读时 这样的话报错是明显的:io.UnsupportedOperation: not writable,不可写应都能
本文向大家介绍ThinkPHP之A方法实例讲解,包括了ThinkPHP之A方法实例讲解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP的A方法用于在内部实例化控制器,其调用格式为: A('[项目://][分组/]模块','控制器层名称') 最简单的用法: 表示实例化当前项目的UserAction控制器(这个控制器对应的文件位于Lib/Action/UserAction.class.php
本文向大家介绍ThinkPHP之R方法实例详解,包括了ThinkPHP之R方法实例详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP的R方法用于调用某个控制器的操作方法,是A方法的进一步增强和补充。 R方法的调用格式: R('[项目://][分组/]模块/操作','参数','控制器层名称') 例如,我们定义了一个操作方法为: 那么就可以通过R方法在其他控制器里面调用这个操作方法(一般R
本文向大家介绍Python读写文件模式和文件对象方法实例详解,包括了Python读写文件模式和文件对象方法实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python读写文件模式和文件对象方法。分享给大家供大家参考,具体如下: 一. 读写文件模式 利用open() 读写文件时,将会返回一个 file 对象,其基本语法格式如: open ( filename, mode) 其中,f