Python中的os.path路径模块中的操作方法总结
解析路径
路径解析依赖与os中定义的一些变量:
- os.sep-路径各部分之间的分隔符。
- os.extsep-文件名与文件扩展名之间的分隔符。
- os.pardir-路径中表示目录树上一级的部分。
- os.curdir-路径中当前目录的部分。
split()函数将路径分解为两个单独的部分,并返回包含这些结果的tuple。第二个元素是路径的最后部分,地一个元素是其他部分。
importos.path forpathin['/one/two/three', '/one/two/three/', '/', '.', '']: print'%15s:%s'%(path,os.path.split(path))
输入参数以os.sep结尾时,最后一个元素是空串。
输出:
/one/two/three:('/one/two','three')
/one/two/three/:('/one/two/three','')
/:('/','')
.:('','.')
:('','')
basename()函数返回的值等价与split()值的第二部分。
importos.path forpathin['/one/two/three', '/one/two/three/', '/', '.', '']: print'%15s:%s'%(path,os.path.basename(path))
整个路径会剥除到只剩下最后一个元素。
输出:
/one/two/three:three /one/two/three/: /: .:. :
dirname()函数返回分解路径得到的第一部分。
importos.path forpathin['/one/two/three', '/one/two/three/', '/', '.', '']: print'%15s:%s'%(path,os.path.dirname(path))
将basename()与dirname()结合,得到原来的路径。
/one/two/three:/one/two /one/two/three/:/one/two/three /:/ .: :
splitext()作用类似与split(),不过它会根据扩展名分隔符而不是目录分隔符来分解路径。importos.path
forpathin['/one.txt', '/one/two/three.txt', '/', '.', '' 'two.tar.gz']: print'%21s:%s'%(path,os.path.splitext(path))
查找扩展名时,只使用os.extsep的最后一次出现。
/one.txt:('/one','.txt')
/one/two/three.txt:('/one/two/three','.txt')
/:('/','')
.:('.','')
two.tar.gz:('two.tar','.gz')
commonprefix()取一个路径列表作为参数,返回一个字符串,表示所有路径中出现的公共前缀。
importos.path paths=['/one/two/three', '/one/two/threetxt', '/one/two/three/four',] forpathinpaths: print'PATH:',path print print'PREFIX:',os.path.commonprefix(paths)
输出:
PATH:/one/two/three PATH:/one/two/threetxt PATH:/one/two/three/four PREFIX:/one/two/three
建立路径
除了分解现有路径外,还需要从其他字符串建立路径,使用join()。
importos.path
forpartsin[('one','two','three'),
('\one','two','three'),
('/one','/two','/three','/four'),]:
printparts,':',os.path.join(*parts)
如果要连接的某个参数以os.sep开头,前面所有参数都会丢弃,参数会返回值的开始部分。
('one','two','three'):one\two\three
('\\one','two','three'):\one\two\three
('/one','/two','/three','/four'):/four
规范化路径
使用join()或利用嵌入变量由单独的字符串组合路径时,得到的路径最后可能会有多余的分隔符或者相对路径部分,使用normpath()可以清除这些内容。
importos.path forpathin['one/two/three', 'one/./two/three', 'one/../alt/two/three', ]: print'%20s:%s'%(path,os.path.normpath(path))
可以计算并压缩有os.curdir和os.pardir构成的路径段。
one/two/three:one\two\three one/./two/three:one\two\three one/../alt/two/three:alt\two\three
要把一个相对路径转换为一个绝对文件名,可以使用abspath()。
importos.path forpathin['.', '..', 'one/two/three', 'one/./two/three', 'one/../alt/two/three', ]: print'%20s:%s'%(path,os.path.abspath(path))
结果是从一个文件系统树最顶层开始的完整路径。
.:C:\Users\Administrator\Desktop ..:C:\Users\Administrator one/two/three:C:\Users\Administrator\Desktop\one\two\three one/./two/three:C:\Users\Administrator\Desktop\one\two\three one/../alt/two/three:C:\Users\Administrator\Desktop\alt\two\three
文件时间
importos importtime print'File:',__file__ print'Accesstime:',time.ctime(os.path.getatime(__file__)) print'Modifiedtime:',time.ctime(os.path.getmtime(__file__)) print'Changetime:',time.ctime(os.path.getctime(__time__)) print'Size:',os.path.getsize(__file__)
返回访问时间,修改时间,创建时间,文件中的数据量。
测试文件
程序遇到一个路径名,通常需要知道这个路径的一些信息。
importos.path filename=r'C:\Users\Administrator\Desktop\tmp' print'File:',filename print'Isfile?:',os.path.isfile(filename) print'Absoulute:',os.path.isabs(filename) print'Isdir?:',os.path.isdir(filename) print'Islink?:',os.path.islink(filename) print'Mountpoint?:',os.path.ismount(filename) print'Exists?:',os.path.exists(filename) print'LinkExists?:',os.path.lexists(filename)
所有测试都返回布尔值。
File:C:\Users\Administrator\Desktop\tmp Isfile?:False Absoulute:True Isdir?:True Islink?:False Mountpoint?:False Exists?:True LinkExists?:True
遍历一个目录树
importos
importos.path
importpprint
defvisit(arg,dirname,names):
printdirname,arg
fornameinnames:
subname=os.path.join(dirname,name)
ifos.path.isdir(subname):
print'%s/'%name
else:
print'%s'%name
print
ifnotos.path.exists('example'):
os.mkdir('example')
ifnotos.path.exists('example/one'):
os.mkdir('example/one')
withopen('example/one/file.txt','wt')asf:
f.write('iloveyou')
withopen('example/one/another.txt','wt')asf:
f.write('iloveyou,two')
os.path.walk('example',visit,'(Userdata)')
会生成一个递归的目录列表。
example(Userdata) one/ example\one(Userdata) another.txt file.txt
一些实际的用法合集:
#创建文件:
os.mknod("test.txt")创建空文件
fp=open("test.txt",w)直接打开一个文件,如果文件不存在则创建文件
#获取扩展名:
>>>os.path.splitext('/Volumes/Leopard/Users/Caroline/Desktop/1.mp4')[1:]
('.mp4',)
>>>os.path.splitext('/Volumes/Leopard/Users/Caroline/Desktop/1.mp4')[1]
'.mp4'
#获取文件名:
>>>printos.path.basename(r'/root/hahaha/123.txt')
123.txt
>>>printos.path.dirname(r'/root/hahaha/123.txt')
/root/hahaha
#判断目录或文件的存在:
>>>os.path.exists('/root/1.py')
True
>>>os.path.exists('/root/')
True
>>>os.path.exists('/root')
True
>>>os.path.isdir('/root')
True
#改变工作目录:
>>>os.chdir('/home')
>>>os.getcwd()
'/home'
#字符串分割:
>>>'/usr/bin/env'.split('/')
['','usr','bin','env']
#获取文件夹大小(Python2.x):
importos
fromos.pathimportjoin,getsize
defgetdirsize(dir):
size=0L
forroot,dirs,filesinos.walk(dir):
size+=sum([getsize(join(root,name))fornameinfiles])
returnsize
if__name__=='__main__':
filesize=getdirsize('/tmp')
print'Thereare%.3f'%(filesize/1024/1024),'Mbytesin/tmp'
#获取文件夹大小(Python3.x):
importos
fromos.pathimportjoin,getsize
defgetdirsize(dir):
size=0
forroot,dirs,filesinos.walk(dir):
size+=sum([getsize(join(root,name))fornameinfiles])
returnsize
if__name__=='__main__':
filesize=getdirsize('/tmp')
print('Thereare'+str(filesize/1024/1024)+'Mbytesin/tmp')