Python中的文件和目录操作实现代码

本文将详细解释这些函数的使用方法。首先,我们介绍Python语言中类似于Windows系统的dir命令的列出文件功能,然后描述如何测试一个文件名对应的是一个标准文件、目录还是链接,以及提取文件大小和日期的方法。之后,我们还将介绍如何删除文件和目录,如何复制和删除文件,以及怎样将一个完整的文件路径分解成目录部分和文件名部分,最后,我们讲解目录的创建,以及如何在目录树中移动目录并处理文件。
  一、显示目录内容
  当我们想要列出当前目录中所有扩展名为.jpg或.gif的文件的时候,就可以使用glob模块来完成此项任务,如下所示:
  import glob
  filelist = glob.glob('*.jpg') + glob.glob('*.gif')
  上述代码使用了glob函数,该函数的参数为要显示的文件类型。在这里,文件类型是通过类似UNIX操作系统shell风格通配符描述的一些文件名来指定的。这些通配符的使用方法,具体请参考fnmatch模块的文档,那里有具体的说明和示例。
  为了显示一个目录中的全部文件,可以使用如下所示的os.listdir函数:


代码如下:

  files = os.listdir(r'C:\hpl\scripting\src\py\intro') #适用于 Windows
  files = os.listdir('/home/hpl/scripting/src/py/intro') # 适用于Unix
  # 跨平台版本:
  files = os.listdir(os.path.join(os.environ['scripting'],
  'src', 'py', 'intro'))
  files = os.listdir(os.curdir) # 当前目录中的所有文件
  files = glob.glob('*') + glob.glob('.*')

  二、测试文件类型
  我们知道,文件名、目录名和链接名都是用一个字符串作为其标识符的,但是给我们一个标识符,我们该如何确定它所指的到底是常规文件文件名、目录名还是链接名呢?这时,我们可以使用os.path模块提供的isfile函数、isdir函数和islink函数来达成我们的目标,如下所示:
  

代码如下:

print myfile, '是一个',
  if os.path.isfile(myfile):
  print 'plain file'
  if os.path.isdir(myfile):
  print 'directory'
  if os.path.islink(myfile):
  print 'link'

  您还可以查找文件的日期及其大小:


代码如下:

  time_of_last_access = os.path.getatime(myfile)
  time_of_last_modification = os.path.getmtime(myfile)
  size = os.path.getsize(myfile)

  这里的时间以秒为单位,并且从1970年1月1日开始算起。为了获取以天为单位的最后访问日期,可以使用下列代码:
  import time # time.time()返回当前时间
  age_in_days = (time.time()-time_of_last_access)/(60*60*24)
  为了获取文件的详细信息,可以使用os.stat函数和stat模块中的其它实用程序来达到目的,如下:


代码如下:

  import stat
  myfile_stat = os.stat(myfile)
  size = myfile_stat[stat.ST_SIZE]
  mode = myfile_stat[stat.ST_MODE]
  if stat.S_ISREG(mode):
  print '%(myfile)是一个常规文件,大小为 %(size)d 字节' %\
  vars()

  有关stat模块的详细信息,请参见Python Library Reference。若想测试一个文件的读、写以及执行权限,可以用os.access函数,具体如下所示:
  if os.access(myfile, os.W_OK):
  print myfile, '具有写权限'
  if os.access(myfile, os.R_OK | os.W_OK | os.X_OK):
  print myfile, '具有读、写以及执行权限'
  像上面这样的测试代码,对CGI脚本来说非常有用。
  三、文件和目录的删除
  若要删除单个文件的话,可以使用os.remove函数,例如:os.remove('mydata.dat')。Os.remove的别名是os.unlink,不过后者跟传统的UNIX操作系统以及Perl中清除文件的函数重名。我们可以使用下列方式来删除一组文件,如所有以.jpg以及*.gif为扩展名的文件:
  for file in glob.glob('*.jpg') + glob.glob('*.gif'):
  os.remove(file)
  大家知道,只有当目录中内容已经被清空的时候,我们才可以使用rmdir命令来删除该目录。不过,我们经常想要删除一个含有许多文件的目录树,这时我们可以使用shutil模块提供的rmtree函数,如下所示:
  shutil.rmtree('mydir')
  它相当于UNIX操作系统中的命令rm -rf mydir。
  我们可以建立一个自定义函数,使其在进行删除操作的时候将文件和目录做同等对待,其典型用法如下所示:
  remove('my.dat') #删除当个文件my.dat
  remove('mytree') #删除单个目录树 mytree
  # 通过字符串列表中的名称来删除多个文件/目录树:
  remove(glob.glob('*.tmp') + glob.glob('*.temp'))
  remove(['my.dat','mydir','yourdir'] + glob.glob('*.data'))
  下面是remove函数的实现:
  def remove(files):
  """删除一个或多个文件和/或目录。"""
  if isinstance(files, str): # files是个字符串吗?
  files = [files] # 把files从字符串转为列表
  if not isinstance(files, list): # files不是列表吗?
  
  for file in files:
  if os.path.isdir(file):
  shutil.rmtree(file)
  elif os.path.isfile(file):
  os.remove(file)
  下面测试一下remove函数的灵活性:


代码如下:

  # 建立10个目录tmp_* ,以及10各文件tmp__*:
  for i in range(10):
  os.mkdir('tmp_'+str(i))
  f = open('tmp__'+str(i), 'w'); f.close()
  remove('tmp_1') # tmp_1为目录
  remove(glob.glob('tmp_[0-9]') + glob.glob('tmp__[0-9]'))

  作为上述remove函数实现的一个注记,我们进行了下列测试:
  if not isinstance(files, list):
  它实际上是过于严厉。我们需要的只是一个被遍历的一个文件/目录名序列。实际上,我们并不关心名称是否存储在一个列表、元组或者数值数组中,所以更好的测试应该像下面这样:
  if not operator.isSequenceType(files):
  
  四、文件的复制与重命名
  当我们要复制文件的时候,可以使用shutil模块:
  import shutil
  shutil.copy(myfile, tmpfile)
  #拷贝最后访问时间和最后修改时间:
  shutil.copy2(myfile, tmpfile)
  # 拷贝一个目录树:
  shutil.copytree(root_of_tree, destination_dir, True)
  Copytree的第三个参数规定对符号链接的处理,其中True表示保留符号链接;而False则意味着使用文件的物理副本替代符号链接。
  Python语言能够很好地支持路径名的跨平台组成:Os.path.join能使用正确的分界符(在UNIX和Mac OS X操作系统中使用/,在 Windows 上使用\)来联接目录和文件名,变量os.curdir和os.pardir分别表示当前工作目录及其父目录。 像下面的UNIX操作系统命令
  cp http://www.jb51.net/f1.c .
  可以使用Python语言提供一个跨平台的实现:
  shutil.copy(os.path.join(os.pardir,os.pardir,'f1.c'), os.curdir)
  Os模块中的rename函数通常被用于重命名一个文件:
  os.rename(myfile, 'tmp.1') # 将myfile重命名为'tmp.1'
  这个函数也可用来在相同的文件系统之内移动文件。这里,我们将myfile移动到目录d下面:
  os.rename(myfile, os.path.join(d, myfile))
  在跨文件系统移动文件的时候,可以先使用shutil.copy2来复制文件,然后再删除原来的副本即可,如下:
  shutil.copy2(myfile, os.path.join(d, myfile))
  os.remove(myfile)
  后面这种移动文件的方法是最安全的。
  五、分解路径名
  假设我们使用变量fname来存放一个包含完整路径的文件名,例如:
  /usr/home/hpl/scripting/python/intro/hw.py
  有时候,我们需要将这样的文件路径拆分为基本名称hw.py和目录名/usr/home/hpl/scripting/python/intro。在Python语言中,可以使用下列代码达到目的:
  basename = os.path.basename(fname)
  dirname = os.path.dirname(fname)
  # 或
  dirname, basename = os.path.split(fname)
  扩展名是通过os.path.splitext函数提取出来的,
  root, extension = os.path.splitext(fname)
  这样,fname中的扩展名部分即.py被赋给变量extension,而其余部分则赋给了变量root。如果想得到不带点号的扩展名的话,只需使用os.path.splitext(fname)[1][1:]即可。
  假设一个文件名为f,其扩展名随意,若想将其扩展名改为ext,可以使用下面的代码:
  newfile = os.path.splitext(f)[0] + ext
  下面是一个具体的示例:
  >>> f = '/some/path/case2.data_source'
  >>> moviefile = os.path.basename(os.path.splitext(f)[0] + '.mpg')
  >>> moviefile
  'case2.mpg'
  六、目录的创建和移动
  Os模块中的函数mkdir可以用来创建目录,而chdir函数则可以移动目录,如下:
  origdir = os.getcwd() # 将当前位置记下来
  newdir = os.path.join(os.pardir, 'mynewdir')
  if not os.path.isdir(newdir):
  os.mkdir(newdir) # 或者os.mkdir(newdir,'0755')
  os.chdir(newdir)
  ...
  os.chdir(origdir) # 返回原目录
  os.chdir(os.environ['HOME']) # 移到主目录
  假设我们想要在自己的主目录下创建一个新目录py/src/test1,但是目前py、src和test1都不存在。如果使用mkdir命令来创建的话,需要使用三次才能建好这个嵌套的目录,但是使用Python语言提供的os.makedirs命令的话,则无需这样麻烦了,该命令可以一次建好整个目录:
  os.makedirs(os.path.join(os.environ['HOME'],'py','src','test1'))
  七、遍历目录树
  下面的函数调用
  os.path.walk(root, myfunc, arg)
  将遍历root目录树;然后,对每个目录名dirname分别调用myfunc(arg, dirname, files)即可,这里参数files是dir中的文件名列表(可通过调用os.listdir(dirname)来获得);arg是用户从调用代码中传递来的参数。对于UNIX操作系统用户来说,Python语言中跨平台的os.path.walk相当于Unix命令find。
  在解释os.path.walk的用法的时候,人们常使用写出主目录中所有子目录内的文件的名称为例进行说明。当然,我们也可以在一个交互式的Python命令行中使用下列代码段来体会os.path.walk的使用:
  def ls(arg, dirname, files):
  print dirname, 'has the files', files
  os.path.walk(os.environ['HOME'], ls, None)
  本例中,参数arg并非必需,所以在os.path.walk调用中让其取值为None即可。
  为了列出主目录中所有大于1Mb的文件,可以使用下面的代码:
  def checksize1(arg, dirname, files):
  for file in files:
  filepath = os.path.join(dirname, file)
  if os.path.isfile(filepath):
  size = os.path.getsize(filepath)
  if size > 1000000:
  size_in_Mb = size/1000000.0
  arg.append((size_in_Mb, filename))
  bigfiles = []
  root = os.environ['HOME']
  os.path.walk(root, checksize1, bigfiles)
  for size, name in bigfiles:
  print name, '大小为', size, 'Mb'
  现在,我们使用arg来建立一个数据结构,这里是一个2元组构成的列表,其中每个2元组存放文件的尺寸(以MB为单位)和完整的文件路径。如果用于所有目录的函数调用中都要更改arg的话,那么arg必须是一个可变的数据结构,即允许适当地进行修改。
  参数dirname是当前正在访问的目录的绝对路径,而参数files内的文件名则是相对于dirname的相对路径。在此期间,当前工作目录并没有改变,那就是说该脚本仍然呆在脚本启动时刻所在的目录中。这就是为什么我们需要把filepath弄成带有dirname和file的绝对路径的原因。若要改变当前工作目录为dirname,只要在针对每个目录调用os.path.walk的函数中调用一下os.chdir(dirname),然后在该函数的末尾重新调用os.chdir(dirname)将当前工作目录改回原值即可,如下所示:
  def somefunc(arg, dirname, files):
  origdir = os.getcwd(); os.chdir(dirname)
  
  os.chdir(origdir)
  os.path.walk(root, somefunc, arg)
  当然,如果您愿意也可以编写具有类似功能的代码来替代os.path.walk。下面的代码,将针对每个文件而非每个目录来调用的自定义函数,如下所示:
  def find(func, rootdir, arg=None):
  # 对rootdir目录中的每个文件调用func
  files = os.listdir(rootdir) # 获取rootdir目录中的所有文件
  files.sort(lambda a, b: cmp(a.lower(), b.lower()))
  for file in files:
  fullpath = os.path.join(rootdir, file)
  if os.path.islink(fullpath):
  pass
  elif os.path.isdir(fullpath):
  find(func, fullpath, arg)
  elif os.path.isfile(fullpath):
  func(fullpath, arg)
  else:
  print 'find: cannot treat ', fullpath
  上面的函数find可以从scitools模块中获取。与内置函数os.path.walk相反,我们的find函数以大小写敏感的字母顺序来访问文件和目录。
  我们可以使用find函数来列出所有大于1Mb的文件:
  def checksize2(fullpath, bigfiles):
  size = os.path.getsize(fullpath)
  if size > 1000000:
  bigfiles.append('%.2fMb %s' % (size/1000000.0, fullpath))
  bigfiles = []
  root = os.environ['HOME']
  find(checksize2, root, bigfiles)
  for fileinfo in bigfiles:
  print fileinfo
  参数arg带来了巨大的灵活性。我们可以使用它来同时存放输入数据和生成的数据结构。下一个范例将收集所有大于一定尺寸的带有规定扩展名的文件的文件名和大小。输出的结果按照文件大小排列。
  bigfiles = {'filelist': [], # 文件名和大小列表
  'extensions': ('.*ps', '.tiff', '.bmp'),
  'size_limit': 1000000, # 1 Mb
  }
  find(checksize3, os.environ['HOME'], bigfiles)
  def checksize3(fullpath, arg):
  treat_file = False
  ext = os.path.splitext(fullpath)[1]
  import fnmatch # Unix的shell风格的通配符匹配
  for s in arg['extensions']:
  if fnmatch.fnmatch(ext, s):
  treat_file = True # fullpath带有正确的扩展名
  size = os.path.getsize(fullpath)
  if treat_file and size > arg['size_limit']:
  size = '%.2fMb' % (size/1000000.0) # 打印
  arg['filelist'].append({'size': size, 'name': fullpath})
  # 按照大小排列文件
  def filesort(a, b):
  return cmp(float(a['size'][:-2]), float(b['size'][:-2]))
  bigfiles['filelist'].sort(filesort)
  bigfiles['filelist'].reverse()
  for fileinfo in bigfiles['filelist']:
  print fileinfo['name'], fileinfo['size']
  注意为列表排序的函数,bigfiles['filelist']函数中的每个元素就是一个字典,键size保存着一个字符串,不过在进行比较之前我们必须将单位Mb(最后两个字符)去掉,并将其转换为浮点数。
  八、小结
  对于文件和目录的处理,虽然可以通过操作系统命令来完成,但是Python语言为了便于开发人员以编程的方式处理相关工作,提供了许多处理文件和目录的内置函数。重要的是,这些函数无论是在Unix、Windows还是Macintosh平台上,它们的使用方式是完全一致的。本文详细解释了这些函数的使用方法,其中,我们首先介绍了显示目录内容的功能,然后描述如何测试一个文件名对应的是一个标准文件、目录还是链接,以及提取文件大小和日期的方法。之后,我们还将介绍如何删除文件和目录,如何复制和删除文件,以及怎样将一个完整的文件路径分解成目录部分和文件名部分,最后,我们讲解目录的创建,以及如何在目录树中移动目录并处理文件。

时间: 2011-03-12

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.判断是

Python读取一个目录下所有目录和文件的方法

本文实例讲述了Python读取一个目录下所有目录和文件的方法.分享给大家供大家参考,具体如下: 这里介绍的是刚学python时的一个读取目录的列子,给大家分享下: #!/usr/bin/python # -*- coding:utf8 -*- import os allFileNum = 0 def printPath(level, path): global allFileNum ''' 打印一个目录下的所有文件夹和文件 ''' # 所有文件夹,第一个字段是次目录的级别 dirList = [

python 文件与目录操作

1)os.path 1.1 os.path.isabs(path) 是否是绝对路径 1.2 os.path.isfile(path) 1.3 os.path.isdir(path) 1.4 os.path.islink(path) 是否是链接:但如果系统不支持链接,返回False 1.5 os.path.ismount(path) 是否为驱动器:但是很不幸的是在python 3.0中这是个不能运行的函数. 原函数如下: # Is a path a mount point? Either a ro

python获取指定目录下所有文件名列表的方法

本文实例讲述了python获取指定目录下所有文件名列表的方法.分享给大家供大家参考.具体实现方法如下: 这里python代码实现获取文件名列表的功能,可以指定文件中包含的字符,方便提取特定类型的文件名列表: # -*- coding: utf-8 -*- #~ #------------------------------------------------------------------ #~ module:wlab #~ Filename:wgetfilelist.py #~ Funct

利用Python查看目录中的文件示例详解

前言 我们在日常开发中,经常会遇到一些关于文件的操作,例如,实现查看目录内容的功能.类似Linux下的tree命令.统计目录下指定后缀文件的行数. 功能是将目录下所有的文件路径存入list中.可以加入后缀判断功能,搜索指定的后缀名文件.主要利用递归的方法来检索文件. 仿造 tree 功能示例代码 Python2.7 列出目录下所有文件 递归法 import os def tree_dir(path, c_path='', is_root=True): """ Get file

Python实现读取目录所有文件的文件名并保存到txt文件代码

代码: (使用os.listdir) 复制代码 代码如下: import os def ListFilesToTxt(dir,file,wildcard,recursion):     exts = wildcard.split(" ")     files = os.listdir(dir)     for name in files:         fullname=os.path.join(dir,name)         if(os.path.isdir(fullname)

python实现删除文件与目录的方法

本文实例讲述了python实现删除文件与目录的方法.分享给大家供大家参考.具体实现方法如下: os.remove(path) 删除文件 path. 如果path是一个目录, 抛出 OSError错误.如果要删除目录,请使用rmdir(). remove() 同 unlink() 的功能是一样的 在Windows系统中,删除一个正在使用的文件,将抛出异常.在Unix中,目录表中的记录被删除,但文件的存储还在. os.removedirs(path) 递归地删除目录.类似于rmdir(), 如果子目

python实现在目录中查找指定文件的方法

本文实例讲述了python实现在目录中查找指定文件的方法.分享给大家供大家参考.具体实现方法如下: 1. 模糊查找 复制代码 代码如下: import os from glob import glob #用到了这个模块 def search_file(pattern, search_path=os.environ['PATH'], pathsep=os.pathsep):     for path in search_path.split(os.pathsep):         for mat

python在指定目录下查找gif文件的方法

本文实例讲述了python在指定目录下查找gif文件的方法.分享给大家供大家参考.具体实现方法如下: #!/usr/bin/python # Use the standard find method to look for GIF files. import sys, find if len(sys.argv) > 1: dirs = sys.argv[1:] else: dirs = [ '.' ] # Go for it. for dir in dirs: files = find.find

使用Python实现从各个子文件夹中复制指定文件的方法

之前用来整理图片的小程序,拿来备忘,算是使用Python复制文件的一个例子. # -*- coding: utf-8 -*- #程序用来拷贝文件并输出图片采集日期等其他信息到Excel中 #文件夹结构: #2016_07_07 # -Data_07_07_001 # -Random1 # -image001_co.pgm # -image001_c1.pgm # -image002_co.pgm # -image002_c1.pgm # --- # -Random2 # --- # -Data_

Java实现从jar包中读取指定文件的方法

本文实例讲述了Java实现从jar包中读取指定文件的方法.分享给大家供大家参考,具体如下: 以下的Java代码实现了从一个jar包中读取指定文件的功能: /** * This class implements the funcationality of reading and writing files in jar files. */ package com.leo.util; import java.io.InputStream; import java.io.FileOutputStrea

python实现在字符串中查找子字符串的方法

本文实例讲述了python实现在字符串中查找子字符串的方法.分享给大家供大家参考.具体如下: 这里实现python在字符串中查找子字符串,如果找到则返回子字符串的位置,如果没有找到则返回-1 S = 'xxxxSPAMxxxxSPAMxxxx' where = S.find('SPAM') # search for position print where # occurs at offset 4 希望本文所述对大家的Python程序设计有所帮助.

Python遍历目录中的所有文件的方法

os.walk生成器 os.walk(PATH), PATH是个文件夹路径,当然可以用.或者../这样啦. 返回的是个三元元组为元素的列表, 每个元素代表了一个文件夹下的内容.第一个就是当前文件夹下内容. 返回的三元元组代表(该工作文件夹, 该文件夹下的文件夹的列表, 该文件夹下文件的列表). 所以, 获得所有子文件夹, 就是(d代表这三元元组): os.path.join(d[0],d[1]); 获得所有子文件, 就是: os.path.join(d[0],d[2]); 以下例子使用了两套循环

在Python的Django框架中生成CSV文件的方法

CSV 是一种简单的数据格式,通常为电子表格软件所使用. 它主要是由一系列的表格行组成,每行中单元格之间使用逗号(CSV 是 逗号分隔数值(comma-separated values) 的缩写)隔开.例如,下面是CSV格式的"不守规矩"的飞机乘客表. Year,Unruly Airline Passengers 1995,146 1996,184 1997,235 1998,200 1999,226 2000,251 2001,299 2002,273 2003,281 2004,3

Python实现的根据文件名查找数据文件功能示例

本文实例讲述了Python实现的根据文件名查找数据文件功能.分享给大家供大家参考,具体如下: #-*- coding: UTF-8 -*- import os import shutil AllFiles=[] NameFiles=[] def findFie(filePath): pathDir = os.listdir(filePath) for allDir in pathDir: # print(allDir) AllFiles.append(allDir) #pass #filepat

Python遍历某目录下的所有文件夹与文件路径

本文与<[Java]读取其下所有文件夹与文件的路径>(点击打开链接)为姊妹篇,主要讲述Python对于文件信息的读取操作. Python对于文件信息的读取操作,在其固有类os中. 下面以读取F盘下的所有文件夹作为例子说明这个问题: Python对于文件夹的遍历有两种写法,一种是直接利用其封装好的walk方法直接操作. 这是Python做得比Java优势的地方: # -*-coding:utf-8-*- import os for root,dirs,files in os.walk("

Python/ArcPy遍历指定目录中的MDB文件方法

如下所示: #遍历指定目录中的MDB文件,构造FeatureClass名 >>> target_folder = 'D:\T20161202' ... file_names=('BOUAN','BOULK','BOUNT','BOUPT','CTRLK','CTRPT','HYDAN','HYDLK','HYDNT','HYDPT','PIPAN','PIPLK','PIPNT','PIPPT','RESAN','RESLK','RESNT','RESPT','ROAAN','ROALK