http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.html
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使用'\r\n',Linux使用'\n'而Mac使用'\r'
指示你正在使用的平台:
os.name
对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'
重命名:
os.rename(old, new)
创建多级目录:
os.makedirs(r“c:\python\test”)
创建单个目录:
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")
换路径
-----------------------------------------------------------------------------------------------------------------------------------------------------------
shutil.copytree("olddir","newdir")要求newdir必须不存在,否则不能使用,其实现如下:
https://docs.python.org/2/library/shutil.html?highlight=shutil
def copytree(src, dst, symlinks=False, ignore=None):
names = os.listdir(src)
if ignore is not None:
ignored_names = ignore(src, names)
else:
ignored_names = set()
os.makedirs(dst)
errors = []
for name in names:
if name in ignored_names:
continue
srcname = os.path.join(src, name)
dstname = os.path.join(dst, name)
if symlinks and os.path.islink(srcname):
linkto = os.readlink(srcname)
os.symlink(linkto, dstname)
elif os.path.isdir(srcname):
copytree(srcname, dstname, symlinks, ignore)
else:
copy2(srcname, dstname)
# XXX What about devices, sockets etc.?
except (IOError, os.error) as why:
errors.append((srcname, dstname, str(why)))
# catch the Error from the recursive copytree so that we can
# continue with other files
except Error as err:
errors.extend(err.args[0])
copystat(src, dst)
except WindowsError:
# can't copy file access times on Windows
except OSError as why:
errors.extend((src, dst, str(why)))
if errors:
raise Error(errors)</span>
要求 “目标目录必须不存在” 限制了其用法,可以通过修改其实现,达到满足目标目录可以存在的需求,很简单修改红色部分即可
http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.htmlpython中对文件、文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块。得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()返回指定目录下的所有文件和目录名:os.listdir()函数用来
shutil.
copy
() 模块具体用法:
shutil.
copy
(source, destination)(这种复制形式使用的前提是必须要有 os.chdir(你要处理的路径))
source/destination 都是字符串形式的路径,其中destination是:
1、可以是一个
文件
的名称,则将source
文件
复制为新名称的destination
2、可以是一个
文件
夹,则将source
文件
复制到destination中
def my
copy
(old
tree
,new
tree
):
if os.path.exists(new
tree
):
shutil.rm
tree
(new
tree
)#如果存在就删除掉
try:shutil.
copy
tree
(old
tree
,new
tree
)
except:print('拷贝失败')
a=r'D:\软件'
b=r'D:\files2'
my
copy
(a,b)
def
copy
tree
(src, dst, symlinks=False, ignore=None,
copy
_function=
copy
2,
ignore_dangling_symlinks=False, dirs_exist_ok=False):
"""Recursively
copy
a directory
tree
and return the destination directory.
dirs_exist_ok dictates whether .
1、shutil.
copy
() 模块具体用法
shutil.
copy
(source, destination)(这种复制形式使用的前提是必须要有 os.chdir(你要处理的路径))
source/destination 都是字符串形式的路劲,其中destination是:
1、可以是一个
文件
的名称,则将source
文件
复制为新名称的destination
2、可以是一个
文件
夹,则将source
文件
复制到destination中
3、若这个
文件
夹不存在,则将source目标
文件
内的内容复制到destinat
最近在处理数据集,经常会使用shutil相关函数处理
文件
,今天专门观察了下
copy
(),
copy
file() 和
copy
tree
() 之间的差别。移动具体
文件
source只能是
文件
,destination可以是
文件
,也可以是
目录
,
目录
必须已经创建,所以在复制
文件
前需要
shutil.
copy
file()
移动具体
文件
source和destination都只能是
文件
把某一
文件
夹(source)内所有
文件
复制到另外一个
文件
夹中(destination),
或者说移动的是
文件
夹和它的内容,目标路径相当于给文
Shutil.
copy
tree
() 是
Python
的一个
文件
和
目录
操作
模块,用于复制整个
目录
树,包括其子
目录
和
文件
。它的语法如下:
shutil.
copy
tree
(src, dst, symlinks=False, ignore=None,
copy
_function=
copy
2, ignore_dangling_symlinks=False)
其中,src 是源
目录
,dst 是目标
目录
,symlinks 表示是否复制软链接,ignore 表示忽略某些
文件
或
目录
,
copy
_function 表示复制
文件
的方式,ignore_dangling_symlinks 表示是否忽略掉错误的软链接。需要注意的是,目标
目录
不能是已经存在的
目录
。
如果您还有其他问题可以继续询问。