• python 读写文件


    文件的打开读写关闭(文件使用完毕后必须关闭,因为文件对象会占用操作系统的资源)

    #写文件
    with open(r'D:Test1.txt','w') as f:           #with比try....finally更加简洁,with自动调用close()方法;open(文件路径,读取方式),r:只读,默认打开方式
          f.write('Hello,world')                    #write(str):写入字符串;writelines():一次性写入多行
    
    #读文件
    with open(r'D:Test1.txt','r') as f:           #r:读
           print f.read()         #read([size]),size可选,指定读取的文件大小,单位是字节,默认读取全部,readline():读取一行;readlines([size]),读取返回一个列表,占内存空间
    
    >>> Hello,world
    >>> try:
           f=open(r'D:Test',r)
           print f.read()
        finally:
            if f:
                f.close()

    文件打开方式:

    +:同时读写,即可读又可写,边写边读、边读边写

    方式 说明 注意 是否清空文件 是否覆盖文件内容 文件不存在是否创建新文件
    ‘r’ 只读 文件不存在时报错 - -
    'r+' 读写 可读可写,文件不存在报错,写入时只覆盖写入文件的大小
    'w' 只写 可写方式打开,不可读 -
    'w+' 读写 可读可写 -
    'a' 追加

    文件已有的内容后追加内容,不可读

    'a+' 追加以及读 可读可追加,写入时,添加到文章末尾,并且指针位于添加后的末尾,所以再次读取会乱码,因为指针指向末尾,读取时实际上是跳过实际要读取的内容,去读取磁盘缓存的上一个文件缓存的内容,所以是乱码
    'rb','wb','ab','rb','wb+','ab+':二进制方式打开
    >>> with open(r'D:Testa.txt','w') as f:
    	     f.write('Hello,world')
    
    >>>with open(r'D:Testa.txt','r') as f:
    	    print f.read()
    
    >>> Hello,world                                        #w写入
    >>> with open(r'D:Testa.txt','a') as f:              #追加,在后面添加内容
    	    f.write('Hello,world')
    >>> with open(r'D:Testa.txt','r') as f:
    	    print f.read()
    >>> Hello,worldHello,world
    >>> with open(r'D:Testa.txt','w') as f:              #清空前面的内容重新写入
    	     f.write('Hello,world')
    
    >>> Hello,world
    

    有关文件可能读取出乱码的问题:

    一:检查下文件的指针的指向,在写完之后,必须要seek(0),把文件指针重新指向文件开头,然后再读,否则就会从缓冲区读取一大堆乱码

    二:文件写入的操作先是在缓存中进行的,只有文件关闭才真正写入,因为read()似乎还是优先读取内存缓冲区。

    以上的两个问题涉及到文件指针的移动seek()以及刷新缓存flush()

    >>> f=open(r'D:Testa.txt','w')
    >>> f.write('kkkkkkkk')                    #此时文件的指针=8,8个字节
    >>> f.flush()                              #刷新缓存,缓存中的内容刷新变成:kkkkkkkk[EOF],内容为空时:[EOF]
    >>> f.read()                               #此时的指针在文件尾[EOF]上,则输出的是''
    ''
    >>> f.seek(0)                              #将指针指向文件头,再进行文件内容的读取,就不会产生乱码
    >>> f.read()
    'kkkkkkkk'
    >>> f.close()
    

     产生乱码例子:

    >>> f=open(r'D:Testa.txt','w+')
    >>> f.write('uuuuuuuuuuuuuuuu')
    >>> f.read()                             #没有刷新缓存且将指针指向文件头,读取的是缓存中的其他乱码内容
    'x00x06x00x00x00@x00x00x00sbx00x00x00dx00x00Zx00x00dx01x00d..............................'
    
  • 相关阅读:
    我给女朋友讲编程CSS系列(2)- CSS语法、3大选择器、选择器优先级
    我给女朋友讲编程CSS系列(1) –添加CSS样式的3种方式及样式表的优先权
    我给女朋友讲编程总结建议篇,怎么学习html和css
    【转给女朋友】提问的艺术:如何快速获得答案
    我给女朋友讲编程网络系列(3)—网页重定向,301重定向,302重定向
    我给女朋讲编程网络系列(2)--IIS8 如何在本地发布网站
    我给女朋友讲编程分享篇--看我姐和我女朋友如何学编程
    我给女朋友讲编程网络系列(4)—颜色值及如何获取颜色值和下载软件小技巧
    我给女朋友讲编程网络系列(1)—什么是域名及域名投资
    Linux就该这么学 20181007第十章Apache)
  • 原文地址:https://www.cnblogs.com/evablogs/p/6725242.html
Copyright © 2020-2023  润新知