zoukankan      html  css  js  c++  java
  • python文件打开方式详解——a、a+、r+、w+、rb、rt区别

    1.排除文件打开方式错误:

    r只读,r+读写,不创建,即需要事先存在一个文件以供读/读写,若不存在文件会报错

    w新建只写,w+新建读写,二者都会将文件内容清零,即事先不需要有该文件存在,若已经存在则会覆盖

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

    w+与r+区别:

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

    r+与a+区别:

    1.  
      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')

    结果:456789

    说明r+进行了覆盖写。

    以a,a+的方式打开文件,附加方式打开

    (a:附加写方式打开,不可读;a+: 附加读写方式打开)

    以 'U' 标志打开文件, 所有的行分割符通过 Python 的输入方法(例#如 read*() ),返回时都会被替换为换行符 . ('rU' 模式也支持 'rb' 选项) . 

    r和U要求文件必须存在

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

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

    1.  
      >>> fd=open(r'f:mypython est.py','w') #只读方式打开,读取报错
    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 est.py','a')#附加写方式打开,读取报错
    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>

    r、rb、rt区别

    使用’r’一般情况下最常用的,但是在进行读取二进制文件时,可能会出现文档读取不全的现象;

    使用’rb’按照二进制位进行读取的,不会将读取的字节转换成字符,二进制文件用二进制读取用’rb’ ;

    rt模式下,python在读取文本时会自动把 转换成 ,文本文件用二进制读取用‘rt’;
     

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

    1.  
      >>> fd=open(r'f:mypython est.py','a+')
    2.  
      >>> fd.write('123')
    3.  
      >>> fd.read()
    4.  
      >>> fd.close()

    close之前,手动打开文件,什么都没写入;close后,手动打开文件,乱码:123嚅?     

    原因分析:指针问题。open()以a+模式开启了一个附加读写模式的文件,由于是a,所以指针在文件末尾。此时如果做read(),则Python发现指针位置就是EOF,读取到空字符串。

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

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

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

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

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

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

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

    原因:同样是指针问题,写入后指针指向末尾[EOF],因此读出空

    解决方案一、调用close后重新打开,指针位于开头。(r,r+,a+,U都可以,注意不要用w,w+,a打开)

    1.  
      >>> fd.close()
    2.  
      >>> fd=open(r'f:mypython est.py','a+')
    3.  
      >>> fd.read()
    4.  
      '456'
    5.  
      >>> fd.close()
    6.  
      >>> fd=open(r'f:mypython est.py','r+')
    7.  
      >>> fd.read()
    8.  
      '456'<pre name="code" class="python">>>> fd.close()
    9.  
      >>> fd=open(r'f:mypython est.py','r')
    10.  
      >>> fd.read()
    11.  
      '456'
    12.  
      >>> fd.close()
    13.  
      >>> fd=open(r'f:mypython est.py','U')
    14.  
      >>> fd.read()
    15.  
      '456'

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

    1.  
      >>> fd=open(r'f:mypython est.py','w+')
    2.  
      >>> fd.write('456')
    3.  
      >>> fd.seek(0)
    4.  
      >>> fd.read()
    5.  
      '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+'来说,如果先读取了内容,再写入的话就变成了追加的模式,如果直接写入内容,就是覆盖了

  • 相关阅读:
    软测试-计算机组成原理、系统和网络安全机构
    POJ 2044 Weather Forecast
    Cocos2d-x 3.x 头像选择,本地相册图片+图片编辑(Android、IOS双平台)
    Spring-----1、Spring一个简短的引论
    捕android程序崩溃日志
    java 正则表达式例子, 查找字符串
    java中Pattern.compile函数的相关解释
    java JdbcTemplate源码
    eclipse 常用快捷键整理
    java 正则表达式去除标点符号
  • 原文地址:https://www.cnblogs.com/Centwei/p/14380639.html
Copyright © 2011-2022 走看看