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

    最近在写的程序频繁地与文件操作打交道,这块比较弱,还好在百度上找到一篇不错的文章,这是原文传送门,我对原文稍做了些改动。

    有关文件夹与文件的查找,删除等功能 在 os 模块中实现。使用时需先导入这个模块,

    导入的方法是:

    import os

    一、取得当前目录

    s = os.getcwd()

    # s 中保存的是当前目录(即文件夹)

    比如运行abc.py,那么输入该命令就会返回abc所在的文件夹位置。

    举个简单例子,我们将abc.py放入A文件夹。并且希望不管将A文件夹放在硬盘的哪个位置,都可以在A文件夹内生成一个新文件夹。且文件夹的名字根据时间自动生成。

    import os

    import time

    folder = time.strftime(r"%Y-%m-%d_%H-%M-%S",time.localtime())
    os.makedirs(r'%s/%s'%(os.getcwd(),folder))
     
    二、更改当前目录

    os.chdir( "C:\123")

    #将当前目录设为 "C:123", 相当于DOC命令的 CD C:123   

    #说明: 当指定的目录不存在时,引发异常。

    异常类型:WindowsError

    Linux下没去试,不知是哪种

    三 将一个路径名分解为目录名和文件名两部分

    fpath , fname = os.path.split( "你要分解的路径")

    例如:

    a, b = os.path.split( "c:\123\456\test.txt" )

    print a

    print b

    显示:

    c:123456

    test.txt

    四   分解文件名的扩展名

    fpathandname , fext = os.path.splitext( "你要分解的路径")

    例如:

    a, b = os.path.splitext( "c:\123\456\test.txt" )

    print a

    print b

    显示:

    c:123456 est

    .txt

    五、判断一个路径( 目录或文件)是否存在


    b = os.path.exists( "你要判断的路径")

    返回值b: True 或 False

    六、判断一个路径是否文件

    b = os.path.isfile( "你要判断的路径")

    返回值b: True 或 False

    七、判断一个路径是否目录

    b = os.path.isdir( "你要判断的路径")

    返回值b: True 或 False

    八、获取某目录中的文件及子目录的列表        

    L = os.listdir( "你要判断的路径")

    例如:

    L = os.listdir( "c:/" )

    print L

    显示 :

    ['1.avi', '1.jpg', '1.txt', 'CONFIG.SYS', 'Inetpub', 'IO.SYS', 'KCBJGDJC', 'KCBJGDYB', 'KF_GSSY_JC', 'MSDOS.SYS', 'MSOCache', 'NTDETECT.COM', 'ntldr', 'pagefile.sys', 'PDOXUSRS.NET', 'Program Files', 'Python24', 'Python31', 'QQVideo.Cache', 'RECYCLER', 'System Volume Information', 'TDDOWNLOAD', 'test.txt', 'WINDOWS']

    这里面既有文件也有子目录

    1 获取某指定目录下的所有子目录的列表

    def getDirList( p ):

            p = str( p )

            if p=="":

                  return [ ]

            p = p.replace( "/","\")

            if p[ -1] != "\":

                 p = p+"\"

            a = os.listdir( p )

            b = [ x   for x in a if os.path.isdir( p + x ) ]

            return b

    print   getDirList( "C:\" )

    结果:

    ['Documents and Settings', 'Downloads', 'HTdzh', 'KCBJGDJC', 'KCBJGDYB', 'KF_GSSY_JC', 'MSOCache', 'Program Files', 'Python24', 'Python31', 'QQVideo.Cache', 'RECYCLER', 'System Volume Information', 'TDDOWNLOAD', 'WINDOWS']

    2 获取某指定目录下的所有文件的列表

    def getFileList( p ):

            p = str( p )

            if p=="":

                  return [ ]

            p = p.replace( "/","\")

            if p[ -1] != "\":

                 p = p+"\"

            a = os.listdir( p )

            b = [ x   for x in a if os.path.isfile( p + x ) ]

            return b

    print   getFileList( "C:\" )

    结果:

    ['1.avi', '1.jpg', '1.txt', '123.txt', '12345.txt', '2.avi', 'a.py', 'AUTOEXEC.BAT', 'boot.ini', 'bootfont.bin', 'CONFIG.SYS', 'IO.SYS', 'MSDOS.SYS', 'NTDETECT.COM', 'ntldr', 'pagefile.sys', 'PDOXUSRS.NET', 'test.txt']

    九、创建子目录

    os.makedirs(   path )   # path 是"要创建的子目录"

    例如:

    os.makedirs(   "C:\123\456\789")

    调用有可能失败,可能的原因是:

    (1) path 已存在时(不管是文件还是文件夹)

    (2) 驱动器不存在

    (3) 磁盘已满

    (4)磁盘是只读的或没有写权限

    十、删除子目录

    os.rmdir( path )   # path: "要删除的子目录"

    产生异常的可能原因:

    (1) path 不存在

    (2) path 子目录中有文件或下级子目录

    (3) 没有操作权限或只读

    测试该函数时,请自已先建立子目录。

    十一、删除文件

    os.remove(   filename )   # filename: "要删除的文件名"

    产生异常的可能原因:

    (1)   filename 不存在

    (2) 对filename文件, 没有操作权限或只读。

    十二、文件改名

    os.name( oldfileName, newFilename)

    产生异常的原因:

    (1) oldfilename 旧文件名不存在

    (2) newFilename 新文件已经存在时,此时,您需要先删除 newFilename 文件。

    ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

    总是记不住API。昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧:

    python中对文件、文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块。

    得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()

    返回指定目录下的所有文件和目录名:os.listdir()

    函数用来删除一个文件:os.remove()

    删除多个目录:os.removedirs(r“c:python”)

    检验给出的路径是否是一个文件:os.path.isfile()

    检验给出的路径是否是一个目录:os.path.isdir()

    判断是否是绝对路径:os.path.isabs()

    检验给出的路径是否真地存:os.path.exists()

    返回一个路径的目录名和文件名:os.path.split()     eg os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt') 

    分离扩展名:os.path.splitext()

    获取路径名:os.path.dirname()

    获取文件名:os.path.basename()

    运行shell命令: os.system()

    读取和设置环境变量:os.getenv() 与os.putenv()

    给出当前平台使用的行终止符:os.linesep    Windows使用' ',Linux使用' '而Mac使用' '

    指示你正在使用的平台:os.name       对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'

    重命名:os.rename(old, new)

    创建多级目录:os.makedirs(r“c:python est”)

    创建单个目录:os.mkdir(“test”)

    获取文件属性:os.stat(file)

    修改文件权限与时间戳:os.chmod(file)

    终止当前进程:os.exit()

    获取文件大小:os.path.getsize(filename)


    文件操作:
    os.mknod("test.txt")        创建空文件
    fp = open("test.txt",w)     直接打开一个文件,如果文件不存在则创建文件

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

    目录操作:
    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 将文件夹下所有图片名称加上'_fc'

    python代码:

    # -*- coding:utf-8 -*-
    import re
    import os
    import time
    #str.split(string)分割字符串
    #'连接符'.join(list) 将列表组成字符串
    def change_name(path):
        global i
        if not os.path.isdir(path) and not os.path.isfile(path):
            return False
        if os.path.isfile(path):
            file_path = os.path.split(path) #分割出目录与文件
            lists = file_path[1].split('.') #分割出文件与文件扩展名
            file_ext = lists[-1] #取出后缀名(列表切片操作)
            img_ext = ['bmp','jpeg','gif','psd','png','jpg']
            if file_ext in img_ext:
                os.rename(path,file_path[0]+'/'+lists[0]+'_fc.'+file_ext)
                i+=1 #注意这里的i是一个陷阱
            #或者
            #img_ext = 'bmp|jpeg|gif|psd|png|jpg'
            #if file_ext in img_ext:
            #    print('ok---'+file_ext)
        elif os.path.isdir(path):
            for x in os.listdir(path):
                change_name(os.path.join(path,x)) #os.path.join()在路径处理上很有用


    img_dir = 'D:\xx\xx\images'
    img_dir = img_dir.replace('\','/')
    start = time.time()
    i = 0
    change_name(img_dir)
    c = time.time() - start
    print('程序运行耗时:%0.2f'%(c))
    print('总共处理了 %s 张图片'%(i))

    输出结果:

    程序运行耗时:0.11
    总共处理了 109 张图片

  • 相关阅读:
    ArrayList removeRange方法分析
    LinkedHashMap源码分析(基于JDK1.6)
    LinkedList原码分析(基于JDK1.6)
    TreeMap源码分析——深入分析(基于JDK1.6)
    51NOD 2072 装箱问题 背包问题 01 背包 DP 动态规划
    51 NOD 1049 最大子段和 动态规划 模板 板子 DP
    51NOD 1006 最长公共子序列 Lcs 动态规划 DP 模板题 板子
    8月20日 训练日记
    CodeForces
    CodeForces
  • 原文地址:https://www.cnblogs.com/fastHro/p/4290159.html
Copyright © 2011-2022 走看看