zoukankan      html  css  js  c++  java
  • python中的文件操作open()函数

    文件操作:

    1、关于open 模式:

    r     以读方式打开,    f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6 eadme.txt","r")

    w     以写方式打开,  如果文件存在则会清洗掉原文件的内容,然后把写的东西写进新文件

    f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6 eadme.txt","w")     #那么原来readme.txt的文件的内容将会被清洗掉

    f.wirte("i am very good")    #那么文件的原内容就会被清洗掉,现在readme.txt的内容只有i am very good 这句话

    以追加模式打开 (从 EOF 开始, 必要时创建新文件)

    >>>f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6
    eadme1.txt","a")
    >>> f.write("i will try my best to beyond myself")
    35     #这个是py3.5.1中会返回写入的句子的总的字节数

    r+   以读写模式打开

     1 f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6
    eadme1.txt","r+",encoding='utf-8')
     2 r=f.tell()         #返回0,说明指针一开始在文章的开头
     3 print(r)          
     4 
     5 content=f.read()
     6 print(content)
     7 #i want to be very execellent
     8 st to beyond myselfi want to be very execellent
     9 ok,i want to be very execellent
    10 以上是读取到的文件的全部内容
    11 r=f.tell()       #返回112 ,就是在文件的末尾,因为在read之后,指针自动跳到最后去
    12 print(r)
    13 content1=f.readline()    
    14 #返回112,指针已经在最后了,向后读没有内容   content1为空
    15 print(content1)
    16 r=f.tell()
    17 print(r)   
    18 w=f.write("ok,i want to be very execellent"+ "
    ")
    19 r1=f.tell()
    20 print(r1)        #返回145,就是写入ok,i want to be very execellent之后,多了33个字节,就是这个字符串的长度
    View Code

    w+  以读写模式打开 (参见 w )

     1 f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6
    eadme1.txt","w+",encoding='utf-8')
     2 r=f.tell()      
     3 print(r)                                 #返回0,在文章的最开头
     4 content=f.read()
     5 print(content)
     6 r=f.tell()
     7 print(r)                                  #返回0,w+模式打开的话,文件内容被清空,所以其实read没有读到任何内容
     8 content1=f.readline()
     9 print(content1)
    10 r=f.tell()
    11 print(r)                                 #跟以上一样
    12 w=f.write("ok,i want to be very execellent"+ "
    ")
    13 r1=f.tell()
    14 print(r1)                               #返回33,就是最后写入的字符串的字节长度
    View Code

    a+  以读写模式打开 (参见 a )

     1 f=open(r"C:UsersshaopengDesktoppy_homeworkDAY6
    eadme1.txt","a+",encoding='utf-8')
     2 r=f.tell()
     3 print(r)                                   # 返回33,以a+的方式打开的话指针跳到文件最后,文件原来长度是33,所以返回33
     4 content=f.read()
     5 print(content)
     6 r=f.tell()                                 #返回33,以a+的方式打开的话指针跳到文件最后,文件原来长度是33, read方法读取完后指针跳到最后,所以返回33
     7 
     8 w=f.write("ok,i want to be very execellent"+ "
    ")
     9 r1=f.tell()
    10 print(r1)                                 #返回66,写入字符串后,指针由原来的33变成33+33,即为66                           
    View Code

    rb    以二进制读模式打开
    wb   以二进制写模式打开 (参见 w )
    ab    以二进制追加模式打开 (参见 a )
    rb+  以二进制读写模式打开 (参见 r+ )
    wb+ 以二进制读写模式打开 (参见 w+ )
    ab+  以二进制读写模式打开 (参见 a+ )

    2、withopen模式,用 with open(文件路径,模式,编码格式) as  文件名:这种方法最后不用自己关闭文件,python会帮你自动关闭文件,用这种模式可以同时打开两个文件 一个读取,一个写进

    >>> with open(r"C:UsersshaopengDesktoppy_homeworkDAY6 eadme.txt","r") as f1,open(r"C:UsersshaopengDesktoppy_homeworkDAY6 eadme1.txt","w") as f2:
    for line in f1:
      f2.write(line)

    这段代码操作之后我的相应的文件夹下就多了一个readme1.txt的文件,内容与readme.txt一模一样

    3、文件中的一些操作方法

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

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

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

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

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

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

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

    f.fileno()                      #返回一个长整型的”文件标签“

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

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

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

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

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

  • 相关阅读:
    Leetcode Plus One
    Leetcode Swap Nodes in Pairs
    Leetcode Remove Nth Node From End of List
    leetcode Remove Duplicates from Sorted Array
    leetcode Remove Element
    leetcode Container With Most Water
    leetcode String to Integer (atoi)
    leetcode Palindrome Number
    leetcode Roman to Integer
    leetcode ZigZag Conversion
  • 原文地址:https://www.cnblogs.com/wspcoding/p/5574253.html
Copyright © 2011-2022 走看看