转载:python文件打开方式详解——a、a+、r+、w+区别

第一步 排除文件打开方式错误:

r只读,r+读写,不创建

w新建只写,w+新建读写,会将文件内容清零

(以w方式打开,不能读出。w+可读写)

**w+与r+区别:

r+:可读可写,若文件不存在,报错;w+: 可读可写,若文件不存在,创建

r+与a+区别:

[python] view plain copy

print?

  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+

[python] view plain copy

print?

  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. File "<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. File "<stdin>", line 1, in <module>
  10. IOError: File not open for reading
  11. >>></span></span></span>

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

[python] view plain copy

print?

  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]为止。所以最后得到了一些根本不期待的随机乱字符,而不是编码问题造成的乱码。

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

[python] view plain copy

print?

  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.文件里有内容,却读出空字符

[python] view plain copy

print?

  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打开)

[python] view plain copy

print?

  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指向开头

[python] view plain copy

print?

  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取负值。

时间: 2024-11-07 22:16:14

转载:python文件打开方式详解——a、a+、r+、w+区别的相关文章

【转】python文件打开方式详解——a、a+、r+、w+区别

原文地址:http://blog.csdn.net/ztf312/article/details/47259805 第一步 排除文件打开方式错误: r只读,r+读写,不创建 w新建只写,w+新建读写,二者都会将文件内容清零 (以w方式打开,不能读出.w+可读写) **w+与r+区别: r+:可读可写,若文件不存在,报错:w+: 可读可写,若文件不存在,创建 r+与a+区别: fd = open("1.txt",'w+') fd.write('123') fd = open("

python文件打开方式详解——a、a+、r+、w+区别

出处: http://blog.csdn.net/ztf312/ 第一步 排除文件打开方式错误: r只读,r+读写,不创建 w新建只写,w+新建读写,二者都会将文件内容清零 (以w方式打开,不能读出.w+可读写) w+与r+区别: r+:可读可写,若文件不存在,报错:w+: 可读可写,若文件不存在,创建 r+与a+区别: [python] view plain copy print? fd = open("1.txt",'w+') fd.write('123') fd = open(&

Python文件打开方式详解——r,w,a,r+,w+,a+

r,r+,w,w+,a,a+作用 r 只读 不创建 r+ 读写 w 新建只写 二者都会将文件清空 w+ 新建读写 a 附加写方式打开,不可读 a+ 附加读写方式打开 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.

Python模块调用方式详解

Python模块调用方式详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 原文地址:https://www.cnblogs.com/yinzhengjie/p/8586301.html

python处理word文件:win32com用法详解

目标:用python处理doc文件 方法:引入win32com模块 ************************************************************************** 一.安装 ************************************************************************** 首先要先下载安装win32com模块(起先在linux下装不成功,后在windows下面成功了...) 下载地址:http

[转载,感觉写的非常详细]DUBBO配置方式详解

[转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是阿里巴巴 SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点. Dubbo采用全spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Sp

(转载)C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区

C++内存分配方式详解--堆.栈.自由存储区.全局/静态存储区和常量存储区       栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清除的变量的存储区.里面的变量通常是局部变量.函数参数等.在一个进程中,位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数的调用.和堆一样,用户栈在程序执行期间可以动态地扩展和收缩. 堆,就是那些由 new 分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个 new 就要对应一个 delete.如果程序员没有释放掉,那么在程序结

Python对Excel操作详解

  Python对Excel操作详解 文档摘要: 本文档主要介绍如何通过python对office excel进行读写操作,使用了xlrd.xlwt和xlutils模块.另外还演示了如何通过Tcl  tcom包对excel操作. 关键字: Python.Excel.xlrd.xlwt.xlutils.TCl.tcom     1 Python简介 Python是一种面向对象.直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定.它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务.

Android 多渠道打包方式详解

Android 多渠道打包方式详解 面试的时候,如果面试官突然问到:你们渠道包是怎么打的?如果你说是用gradle一个一个编译的,然后他很鄙视的说这个效率太低啦,你们写过什么脚本自己打渠道包没?你肯定心里想,卧槽,这么狂炫吊炸天,自己写脚本打包?!其实这个根本也不是太难啦!!今天就来聊聊多渠道打包的原理以及如何自己DIY多渠道打包的工具! 渠道包出现 当一个产品到发版的时候,我们搞Android的就会面临一个超级尴尬的问题:国内这么多的渠道,渠道统计是必须做滴,那么十多个主要渠道再加无限量的地推