zoukankan      html  css  js  c++  java
  • Python读写文件

    给要打开的文件对象指定一个名字,这样可在完成操作之后迅速关闭文件,防止一些无用的文件对象占用内存

     
    1
    2
    3
    4
    5
    file_object = open('thefile.txt')
    try:
    all_the_text = file_object.read( )
    finally:
    file_object.close( )

    Python读写文件的五大步骤
    一、打开文件
    Python读写文件在计算机语言中被广泛的应用,如果你想了解其应用的程序,以下的文章会给你详细的介绍相关内容,会你在以后的学习的过程中有所帮助,下面我们就详细介绍其应用程序。
    代码如下:

     
    1
    = open("d: est.txt""w")

    说明:
    第一个参数是文件名称,包括路径;第二个参数是打开的模式mode
    'r':只读(缺省。如果文件不存在,则抛出错误)
    'w':只写(如果文件不存在,则自动创建文件)
    'a':附加到文件末尾
    'r+':读写
    如果需要以二进制方式打开文件,需要在mode后面加上字符"b",比如"rb""wb"等
    二、读取内容
    f.read(size) 
    参数size表示读取的数量,可以省略。如果省略size参数,则表示读取文件所有内容。
    f.readline() 
    读取文件一行的内容
    f.readlines() 
    读取所有的行到数组里面[line1,line2,...lineN]。在避免将所有文件内容加载到内存中,这种方法常常使用,便于提高效率。
    三、写入文件

    f.write(string) 
    将一个字符串写入文件,如果写入结束,必须在字符串后面加上" ",然后f.close()关闭文件

    四、文件中的内容定位
    f.read() 
    读取之后,文件指针到达文件的末尾,如果再来一次f.read()将会发现读取的是空内容,如果想再次读取全部内容,必须将定位指针移动到文件开始:
    f.seek(0) 
    这个函数的格式如下(单位是bytes):
    f.seek(offset, from_what) 
    from_what表示开始读取的位置,offset表示从from_what再移动一定量的距离,比如f.seek(10, 3)表示定位到第三个字符并再后移10个字符。from_what值为0时表示文件的开始,它也可以省略,缺省是0即文件开头。

     
    1
    2
    3
    4
    5
    6
    7
    8
    = open('/tmp/workfile''r+')
    f.write('0123456789abcdef')
    f.seek(5# Go to the 6th byte in the file
    f.read(1
    '5'
    f.seek (-32# Go to the 3rd byte before the end
    f.read(1)
    'd'
    五、关闭文件释放资源
    文件操作完毕,一定要记得关闭文件f.close(),可以释放资源供其他程序使用
    Python读写文件在计算机语言中被广泛的应用,如果你想了解其应用的程序,以下的文章会给你详细的介绍相关内容,会你在以后的学习的过程中有所帮助,下面我们就详细介绍其应用程序。

    Python中文件的读写操作的几种方法

     

    对文件的操作,步骤为:打开一个文件-->读取/写入内容-->保存文件

    文件读写的3中模式

    复制代码
    # 1、w 写模式,它是不能读的,如果用w模式打开一个已经存在的文件,会清空以前的文件内容,重新写
    #    w+ 是读写内容,只要沾上w,肯定会清空原来的文件
    # 2、r 读模式,只能读,不能写,而且文件必须存在
    #    r+ 是读写模式,只要沾上r,文件必须存在
    # 3、a 追加模式,也能写,在文件的末尾添加内容
    # 4、rb+、wb+、ab+,这种是二进制模式打开或者读取,一些音乐文件
    复制代码
    test1.txt
    复制代码
     1 如果无情的风摘走了那片树叶
     2 如同摘走了我的心
     3 在每一个想你的夜晚
     4 请允许我将你抱紧
     5 我不像一只大雁可以秋去春来
     6 衔回丢失的缘分
     7 所以从来不敢回忆离别
     8 越是清晰 越是伤心
     9 你说所有的城市没有不同
    10 我宁愿相信你心中有片草原
    复制代码
    1、循环读取文件中的每一行内容:
    demo1.py
    1 file = open('test1.txt','r+')# 打开test1.txt 文件
    2 for line in file: # 遍历file文件
    3     print('line里面存放的是:',line) # 循环打印文件中每一行内容
    4     print(type(line)) # <class 'str'> 类型是字符串
    5 file.close()# 关闭文件

    用with的方式打开文件,不用担心使用完文件后忘记关闭,它会自动将文件关闭
    1 with open('test1.txt','r+') as file:
    2     for line in file:
    3         print('line里面存放的是:',line) # 循环打印文件中每一行内容
    4         print(type(line)) # <class 'str'> 类型是字符串
    3、向文件中写入内容
    1 with open('users','a+') as fw: # 打开文件
    2     fw.write('写入文件内容')
    4、用函数的方式读取文件
    复制代码
     1 def read_file(filename):
     2     '''
     3     用来读取文件内容
     4     :param filename: 文件名
     5     '''
     6     with open(filename,'a+') as fr:
     7         fr.seek(0) # 移动文件指针
     8         content = fr.read() # content 类型是字符串
     9         print('content:',content)
    10 read_file('users') # 调用函数
    复制代码
    5、用函数的方式写文件
    复制代码
     1 def write_file(filename,content):
     2     '''
     3     用来读取文件内容的
     4     :param filename: 文件名
     5     '''
     6     with open(filename,'a+') as fw:
     7         fw.seek(0) # 移动文件指针
     8         fw.truncate() # 清空文件内容
     9         fw.write(str(content))
    10 write_file('a','hello world') # 调用函数
     

    open()和close()方法:
    使用python的内置函数open()打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。

    file object = open(file_name [, access_mode][, buffering])

    file_name:文件路径
    access_mode:文件打开方式(r,r+,w,w+.....)
    buffering:如果buffering的值被设为0,就不会有寄存。如果buffering的值取1,访问文件时会寄存行。如果将buffering的值设为大于1的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。

    重点介绍一下access_mode:
    r:使用文件以只读的方式打开,指针会定位到文档的开头;
    r+:使用文件以读写的方式打开,指针会定位到文档的开头;

    使用“r/r+”操作文件,若文件不存在,会在指定的路径下创建对应文件名的文件,若存在,则进行读取

    w:使用文件以只写的方式打开,指针会定位到文档的开头;
    w+:使用文件以读写的方式打开,指针会定位到文档的开头;
    使用“w/w+”操作文件,若文件不存在,会在指定路径下创建对应文件名的文件;若存在,则会对已存在的文件进行覆盖(并将原文件内容清空)

    close()方法:一般在使用open()打开文件之后都会将文件进行close()

    文件的read方法:
    read()、readlines()、readline()

    fileObject.read([count]):count表示从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,很可能是直到文件的末尾。

    fileObject.readline([size]); size -- 从文件中读取的字节数 readline()方法每次读取文件中的一行,当传入size作为参数时,代表从当前行读取的字节数

    read()和readline()方法返回的都是字符串

    fileObject.readlines( );readlines()从文件中读取所有的行,以列表的型式返回,可以循环从列表中接收对应的字符串

    read()、readline()方法执行之后,指针指到了文件的读到的位置,可通过tell()方法获取文件指针当前位置,执行read之类的方法之后若想将文件指针指到文件开头,可使用seek(offset [,from])方法,offset表示移动的字节数,from表示从哪个位置开始移动
    若指向文件的开头,可设置为seek(0,0)或者使用close()将文件关闭

    一、python中对文件、文件夹操作时经常用到的os模块和shutil模块常用方法。

    1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()
    2.返回指定目录下的所有文件和目录名:os.listdir()
    3.函数用来删除一个文件:os.remove()
    4.删除多个目录:os.removedirs(r"c:python")
    5.检验给出的路径是否是一个文件:os.path.isfile()
    6.检验给出的路径是否是一个目录:os.path.isdir()
    7.判断是否是绝对路径:os.path.isabs()
    8.检验给出的路径是否真地存:os.path.exists()
    9.返回一个路径的目录名和文件名:os.path.split() 
    例子:
    代码如下:
    os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt')

    10.分离扩展名:os.path.splitext()
    11.获取路径名:os.path.dirname()
    12.获取文件名:os.path.basename()
    13.运行shell命令: os.system()
    14.读取和设置环境变量:os.getenv() 与os.putenv()
    15.给出当前平台使用的行终止符:os.linesep Windows使用' ',Linux使用' '而Mac使用' '
    16.指示你正在使用的平台:os.name 对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'
    17.重命名:os.rename(old, new)
    18.创建多级目录:os.makedirs(r"c:python est")
    19.创建单个目录:os.mkdir("test")
    20.获取文件属性:os.stat(file)
    21.修改文件权限与时间戳:os.chmod(file)
    22.终止当前进程:os.exit()
    23.获取文件大小:os.path.getsize(filename)
    二、文件操作方法大全
    1.os.mknod("test.txt") 创建空文件
    2.fp = open("test.txt",w) 直接打开一个文件,如果文件不存在则创建文件
    3.关于open 模式:

    代码如下:

    r:以读方式打开文件,可读取文件信息。
    w:以写方式打开文件,可向文件写入信息。如文件存在,则清空该文件,再写入新内容
    a:以追加模式打开文件(即一打开文件,文件指针自动移到文件末尾),如果文件不存在则创建
    b:以二进制模式打开文件,而不是以文本模式。该模式只对Windows或Dos有效,类Unix的文件是用二进制模式进行操作的。
    r+:以读写模式打开
    w+:以读写模式打开 (参见 w )
    a+:以读写模式打开 (参见 a )
    rb:以二进制读模式打开
    wb:以二进制写模式打开 (参见 w )
    ab:以二进制追加模式打开 (参见 a )
    rb+:以二进制读写模式打开 (参见 r+ )
    wb+:以二进制读写模式打开 (参见 w+ )
    ab+:以二进制读写模式打开 (参见 a+ )

    文件对象方法
    f.close():关闭文件,记住用open()打开文件后一定要记得关闭它,否则会占用系统的可打开文件句柄数。
    f.fileno():获得文件描述符,是一个数字
    f.flush():刷新输出缓存
    f.isatty():如果文件是一个交互终端,则返回True,否则返回False。
    f.read([count]):读出文件,如果有count,则读出count个字节。
    f.readline():读出一行信息。
    f.readlines():
    读出所有行,也就是读出整个文件的信息。
    f.seek(offset[,where]):把文件指针移动到相对于where的offset位置。where为0表示文件开始处,这是默认值 ;1表示当前位置;2表示文件结尾。
    f.tell():获得文件指针位置。
    f.truncate([size]):截取文件,使文件的大小为size。
    f.write(string):把string字符串写入文件。
    f.writelines(list):把list中的字符串一行一行地写入文件,是连续写入文件,没有换行。

    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把文件补到相应的大小,也可能是以一些随机的内容加上去。

    三、目录操作方法大全

    1.创建目录

    os.mkdir("file")                   
    2.复制文件:
    shutil.copyfile("oldfile","newfile")        #oldfile和newfile都只能是文件
    shutil.copy("oldfile","newfile")            #oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
    3.复制文件夹:
    4.shutil.copytree("olddir","newdir")        #olddir和newdir都只能是目录,且newdir必须不存在
    5.重命名文件(目录)
    os.rename("oldname","newname")              #文件或目录都是使用这条命令
    6.移动文件(目录)
    shutil.move("oldpos","newpos")   
    7.删除文件
    os.remove("file")
    8.删除目录
    os.rmdir("dir")                             #只能删除空目录
    shutil.rmtree("dir")                        #空目录、有内容的目录都可以删
    9.转换目录
    os.chdir("path")                            #换路径


    目录操作:
    os.mkdir("file")                   创建目录
    复制文件:
    shutil.copyfile("oldfile","newfile")       oldfile和newfile都只能是文件
    shutil.copy("oldfile","newfile")            oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
    复制文件夹:
    shutil.copytree("olddir","newdir")        olddir和newdir都只能是目录,且newdir必须不存在
    重命名文件(目录)
    os.rename("oldname","newname")       文件或目录都是使用这条命令
    移动文件(目录)
    shutil.move("oldpos","newpos")   
    删除文件
    os.remove("file")
    删除目录
    os.rmdir("dir")只能删除空目录
    shutil.rmtree("dir")    空目录、有内容的目录都可以删
    转换目录
    os.chdir("path")   换路径

    编程实例: 

     
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    # -*- coding: utf-8 -*-
      
    import os
    import shutil
      
    # 一. 路径操作:判断、获取和删除
      
    #1. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()
    #print: currentpath: f:LearnPython
    currentpath = os.getcwd()
    print "currentpath: ",currentpath
    #2. 返回指定目录下的所有文件和目录名:os.listdir()
    #print:os.listdir(): ['test.txt', 'testRW.py', 'test1.txt', 'cmd.py', 'rwfile.py', 'downloadfile.py', 'date.py', 'time.py', 'datetime.py', 'file.py']
    print "os.listdir(): ",os.listdir('f:LearnPython')
      
    path = "F:mmmmmmmmmdebug_taobao_200003@taobao_android1.6_3.2.1.apk"
    #3. 判断给出的路径是否真地存:os.path.exists()
    if os.path.exists(path):
      #删除一个文件:os.remove()
      os.remove(path)
    else:
      print path,"not exist"
      
    #4. 删除多个目录:os.removedirs(“c:python”)
    #它只能删除空目录,如果目录里面有内容将不会被删除
    if os.path.exists("d:/woqu"):
      os.removedirs("d:/woqu")
    else:
      os.mkdir("d:/woqu")
      os.removedirs("d:/woqu")
      
    #5. 判断给出的路径是否是一个文件:os.path.isfile()
    #print: True
    print os.path.isfile("D:hellojson.txt")
    #6. 判断给出的路径是否是一个目录:os.path.isdir()
    #print: True
    print os.path.isdir("D:hello")
    #7. 判断是否是绝对路径:os.path.isabs()
    #print: True
    print os.path.isabs("D:hello")
    # 判断是否是链接
    print os.path.islink('http://www.baidu.com')
    #8. 返回一个路径的目录名和文件名:os.path.split()   
    #eg os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt') 
    #print: ('D:\hello', 'json.txt')
    print os.path.split("D:hellojson.txt")
    #9. 分离扩展名:os.path.splitext()
    #print:('D:\hello\json', '.txt')
    print os.path.splitext("D:hellojson.txt")
    #10. 获取路径名:os.path.dirname()
    #print: 'D:\hello'
    print os.path.dirname("D:hellojson.txt")
    #11. 获取文件名:os.path.basename()
    #print: 'json.txt'
    print os.path.basename("D:hellojson.txt")
      
      
    #13. 指示你正在使用的平台:os.name    对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'
    print "os.name: ",os.name
      
    #14. linex 下的命令
    if os.name == 'posix':
      #读取和设置环境变量:os.getenv() 与os.putenv()
      home_path = os.environ['HOME']
      home_path = os.getenv('HOME'#读取环境变量 
    elif os.name == 'nt':
      home_path = 'd:' 
      print 'home_path: ',home_path
      
    #15. 给出当前平台使用的行终止符:os.linesep  Windows使用' ',Linux使用' '而Mac使用' '
    print(os.linesep)
      
    #16. 应为windows和linux的路径有点点不一样,windows是用 \ 来分割的,linux是用 / 来分隔,
    #而用os.sep 会自动根据系统选择用哪个分隔符。
    print(os.sep)
      
    #17. 重命名:os.rename(old, new)
    #先进入目录
    os.chdir("d:\hello")
    print os.getcwd() 
    #18. 再重命名
    os.rename("1.txt""11.txt")
    #19. 创建多级目录:os.makedirs(“c:python est”)
    os.makedirs('d:hello')
    #20. 创建单个目录:os.mkdir(“test”)
    os.mkdir('d:f')
    #21. 获取文件属性:os.stat(file)
    #print: nt.stat_result(st_mode=33206, st_ino=0L, st_dev=0, st_nlink=0, st_uid=0, st_gid=0, st_size=497L, st_atime=1346688000L, st_mtime=1346748054L, st_ctime=1346748052L)
    print os.stat('d:hellojson.txt')
    #22. 修改文件权限与时间戳:os.chmod(path,mode)
    #23. 终止当前进程:os.exit()
    #24. 获取文件大小:os.path.getsize(filename)
    print os.path.getsize('d:/hello/json.txt')

    python中如何将列表写入文件:
    实例:

     
    1
    2
    3
    4
    5
    = [1,2,3,4,5,6,7,8,9]
    tmp = []
    for in range(0,len(a),3):
     tmp.append(str(a[i])+","+str(a[i+1])+","+str(a[i+2])+" ")
    file("./a.txt",'w').writelines(tmp)

    python 读取txt文件到列表中
    实例:
    假如txt文件内容为:aaa,bbb,ccc
    ddd,eee,fff

    我要读取保存到列表中去,显示结果为[[aaa,bbb,ccc],[ddd,eee,fff]]

    1
    2
    3
    4
    5
    6
    7
    txtpath=r"a.txt"
    fp=open(txtpath)
    arr=[]
    for lines in fp.readlines():
      lines=lines.replace(" ","").split(",")
      arr.append(lines)
    fp.close()
  • 相关阅读:
    安装VMtools vim编辑器的使用 压缩包命令 Linux下的用户管理 (第三天)
    VM虚拟机安装 常用Linux命令 网卡配置 (第二天)
    数据库的交互模式 常用的dos命令 (第一天)
    Validate US Telephone Numbers FreeCodeCamp
    Arguments Optional FreeCodeCamp
    Everything Be True FreeCodeCamp
    Binary Agents FreeCodeCamp
    Steamroller FreeCodeCamp
    Drop it FreeCodeCamp
    Smallest Common Multiple FreeCodeCamp
  • 原文地址:https://www.cnblogs.com/klb561/p/10555790.html
Copyright © 2011-2022 走看看