zoukankan      html  css  js  c++  java
  • python文件操作

    fiel1.txt

    君不见,黄河之水天上来,奔流到海不复回。
    君不见,高堂明镜悲白发,朝如青丝暮成雪。
    人生得意须尽欢,莫使金樽空对月。
    天生我材必有用,千金散尽还复来。
    烹羊宰牛且为乐,会须一饮三百杯。
    岑夫子,丹丘生,将进酒,杯莫停。
    与君歌一曲,请君为我倾耳听。(倾耳听 一作:侧耳听)
    钟鼓馔玉不足贵,但愿长醉不复醒。(不足贵 一作:何足贵;不复醒 一作:不愿醒/不用醒)
    古来圣贤皆寂寞,惟有饮者留其名。(古来 一作:自古;惟 通:唯)
    陈王昔时宴平乐,斗酒十千恣欢谑。
    主人何为言少钱,径须沽取对君酌。
    五花马,千金裘,呼儿将出换美酒,与尔同销万古愁。

    def read_file():
        with open('fiel1.txt', 'r', encoding='utf-8') as f:
            print('---------------------------readline')
            f.readline() # 读一行
            t1 = f.tell()  # 记录当前光标位置为下一行开头
            print(t1)
            f.seek(t1)  #  把光标位置移动到下一行开头
            print(f.readline())  #  打印第二行
            print('---------------------------readline')
            f.seek(0)
            f.readline(2)  #  读俩个字符(英文也是)
            t2 = f.tell()
            f.seek(t2)
            print(f.readline())
            print('------------------------------打印列表')
            f.seek(0)  #  把光标移动到文件开始
            li = f.readlines()  #  把文件内容读取成一个列表
            for i in li:
                print(i)
            print('----------------------------read')
            f.seek(0)
            print(f.read(1))  #  读一个字符(英文也是) 光标当前位置开始
            f.seek(18)  # 光标指向第15个字节,一个中文字符是3个字节,如果参数值不是3的倍数,会报错
            print(f.read(1))
            print('----------------------------read')
            f.seek(0)
            print(f.read())  #  都所有内容,文件太大会报错
            print('----------------------------write')
            f.seek(0)
            fw1 = f.readline()
            print(fw1)
            with open('fiel12.txt', 'a+', encoding='utf-8') as fw:
                fw.write(fw1)
            print('----------------------------writelines')
            f.seek(0)
            fw1 = f.readline()
            print(fw1)
            with open('fiel122.txt', 'a+', encoding='utf-8') as fw:
                fw.writelines(f.read())  #  把读的所有内容原样子写入,包括换行
            print('-----------------------------------删除某一行')
            f.seek(0)
            li_del = f.readlines()
            del li_del[2]   # 删除索引是2的一行
            with open('fiel3.txt', 'w+', encoding='utf-8') as fw:
                fw.write(''.join(li_del))  # 把列表中数据转换成原来格式

    read_file()

    关于open 模式:

    w 以写方式打开,
    a 以追加模式打开 (从 EOF 开始, 必要时创建新文件)
    r+ 以读写模式打开
    w+ 以读写模式打开 (参见 w )
    a+ 以读写模式打开 (参见 a )
    rb 以二进制读模式打开
    wb 以二进制写模式打开 (参见 w )
    ab 以二进制追加模式打开 (参见 a )
    rb+ 以二进制读写模式打开 (参见 r+ )
    wb+ 以二进制读写模式打开 (参见 w+ )
    ab+ 以二进制读写模式打开 (参见 a+ )

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

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

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

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

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

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

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

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

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

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

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

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

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

  • 相关阅读:
    164 Maximum Gap 最大间距
    162 Find Peak Element 寻找峰值
    160 Intersection of Two Linked Lists 相交链表
    155 Min Stack 最小栈
    154 Find Minimum in Rotated Sorted Array II
    153 Find Minimum in Rotated Sorted Array 旋转数组的最小值
    152 Maximum Product Subarray 乘积最大子序列
    151 Reverse Words in a String 翻转字符串里的单词
    bzoj3994: [SDOI2015]约数个数和
    bzoj 4590: [Shoi2015]自动刷题机
  • 原文地址:https://www.cnblogs.com/fmgao-technology/p/9108506.html
Copyright © 2011-2022 走看看