python基础5 ---python文件处理

python文件处理python

1、文件处理的流程函数

  1. 打开文件,获得文件句柄并赋值给一个变量
  2. 经过句柄对文件进行操做
  3. 关闭文件

2、文件的操做方法编码

  一、文件打开模式格式:spa

    文件句柄 = open('文件路径', '模式')操作系统

  注释:打开文件时,须要指定文件路径和以何等方式打开文件,打开后,便可获取该文件句柄,往后经过此文件句柄对该文件操做。unix

  二、文件打开模式:code

     r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】blog

     w,只写模式【不可读;不存在则建立;存在则清空内容】内存

      x, 只写模式【不可读;不存在则建立,存在则报错】it

     a, 追加模式【可读;   不存在则建立;存在则只追加内容】

     b"表示以字节的方式操做 :rb  或 r+b

                wb 或 w+b

                xb 或 w+b

                ab 或 a+b

    补充:r、w、a为打开文件的基本模式,对应着只读、只写、追加模式;b、t、+、U这四个字符,与以上的文件打开模式组合使用,二进制模式,文本模式,读写模式、     通用换行符,根据实际状况组合使用、

  三、文件内置函数flush

    flush原理: 文件操做是经过软件将文件从硬盘读到内存 ,写入文件的操做也都是存入内存缓冲区buffer(内存速度快于硬盘,若是写入文件的数据都从内存刷到硬盘,内存与硬盘的速度延迟会被无限放大,效率变低,因此要刷到硬盘的数据咱们统一往内存的一小块空间即buffer中放,一段时间后操做系统会将buffer中数据一次性刷到硬盘).flush的做用是强制将写入的数据刷到硬盘。

  四、open函数详解

    open()语法
         格式:open(file[, mode[, buffering[, encoding[, errors[, newline[, closefd=True]]]]]])

    open函数有不少的参数,经常使用的是file,mode和encoding
    file文件位置,须要加引号
    mode文件打开模式
    buffering的可取值有0,1,>1三个,0表明buffer关闭(只适用于二进制模式),1表明line buffer(只适用于文本模式),>1表示初始化的buffer大小;
    encoding表示的是返回的数据采用何种编码,通常采用utf8或者gbk;
    errors的取值通常有strict,ignore,当取strict的时候,字符编码出现问题的时候,会报错,当取ignore的时候,编码出现问题,程序会忽略而过,继续执行下面的程序。
    newline能够取的值有None, \n, \r, ”, ‘\r\n',用于区分换行符,可是这个参数只对文本模式有效;
    closefd的取值,是与传入的文件参数有关,默认状况下为True,传入的file参数为文件的文件名,取值为False的时候,file只能是文件描述符,什么是文件描述符,就是一个非负整数,在Unix内核的系统中,打开一个文件,便会返回一个文件描述符。

   五、文件操做参数

   .read([size])         #size为读取的长度,以byte为单位

 

   .readline([size])       #读一行,若是定义了size,有可能返回的只是一行的一部分

 

   .readlines([size])       #把文件每一行做为一个list的一个成员,并返回这个list。其实它的内部是经过循环调用readline()来实现的。若是提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。

 

   .write(str)          #把str写到文件中,write()并不会在str后加上一个换行符

 

   .writelines(seq)        #把seq的内容所有写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。

 

   .close()            #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好仍是养成本身关闭的习惯。  若是一个文件在关闭后还对其进行操做会产生ValueError

 

   .flush()            #把缓冲区的内容写入硬盘

 

   .isatty()            #文件是不是一个终端设备文件(unix系统中的)

 

   .tell()             #返回文件操做标记的当前位置,以文件的开头为原点

 

   .next()                #返回下一行,并将文件操做标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。

 

   .seek(offset[,whence])#将文件打操做标记移到offset的位置。这个offset通常是相对于文件的开头来计算的,通常为正数。但若是提供了whence参数就不必定了,whence能够为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。须要注意,若是文件以a或a+的模式打开,每次进行写操做时,文件操做标记会自动返回到文件末尾。

   .truncate([size])        #把文件裁成规定的大小,默认的是裁到当前文件操做标记的位置。若是size比文件的大小还要大,依据系统的不一样多是不改变文件,也多是用0把文件补到相应的大小,也多是以一些随机的内容加上去

   六、上下文管理实例。

with open('a.txt','w') as f:
    pass
with open('a.txt','r') as read_f,open('b.txt','w') as write_f:
    data=read_f.read()
    write_f.write(data)
相关文章
相关标签/搜索