• python文件操作


    一、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()     eg 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 模式:

    复制代码代码例如以下:
    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把文件补到对应的大小,也可能是以一些随机的内容加上去。
    三、文件夹操作方法大全
    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")                            #换路径

  • 相关阅读:
    “混乱有序”一首关于概率论的诗
    关于“混乱有序”理论的讨论 2020-09-20
    关于“混乱有序”理论的讨论 2020-08-30
    【Java】(有步骤!)模逆、模幂、十进制转十六进制、十六进制转十进制、xTime算法、LFSR画状态图、椭圆曲线加法、椭圆曲线乘法、获得椭圆曲线上的点
    算法导论第一课
    经典力学:第一课
    计算机科学及编程导论:第一课
    微积分重点:第十六至十八课
    微积分重点:第十四,十五课
    微积分重点:第十课至十三课
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/7073794.html
Copyright © 2020-2023  润新知