Python中的os.path路徑模塊中的操作方法總結(jié)
解析路徑
路徑解析依賴與os中定義的一些變量:
- os.sep-路徑各部分之間的分隔符。
- os.extsep-文件名與文件擴展名之間的分隔符。
- os.pardir-路徑中表示目錄樹上一級的部分。
- os.curdir-路徑中當(dāng)前目錄的部分。
split()函數(shù)將路徑分解為兩個單獨的部分,并返回包含這些結(jié)果的tuple。第二個元素是路徑的最后部分,地一個元素是其他部分。
import os.path
for path in [ '/one/two/three',
'/one/two/three/',
'/',
'.',
'']:
print '%15s : %s' % (path, os.path.split(path))
輸入?yún)?shù)以os.sep結(jié)尾時,最后一個元素是空串。
輸出:
/one/two/three : ('/one/two', 'three')
/one/two/three/ : ('/one/two/three', '')
/ : ('/', '')
. : ('', '.')
: ('', '')
basename()函數(shù)返回的值等價與split()值的第二部分。
import os.path
for path in [ '/one/two/three',
'/one/two/three/',
'/',
'.',
'']:
print '%15s : %s' % (path, os.path.basename(path))
整個路徑會剝除到只剩下最后一個元素。
輸出:
/one/two/three : three
/one/two/three/ :
/ :
. : .
:
dirname()函數(shù)返回分解路徑得到的第一部分。
import os.path
for path in [ '/one/two/three',
'/one/two/three/',
'/',
'.',
'']:
print '%15s : %s' % (path, os.path.dirname(path))
將basename()與dirname()結(jié)合,得到原來的路徑。
/one/two/three : /one/two
/one/two/three/ : /one/two/three
/ : /
. :
:
splitext()作用類似與split(),不過它會根據(jù)擴展名分隔符而不是目錄分隔符來分解路徑。import os.path
for path in [ '/one.txt',
'/one/two/three.txt',
'/',
'.',
''
'two.tar.gz']:
print '%21s : %s' % (path, os.path.splitext(path))
查找擴展名時,只使用os.extsep的最后一次出現(xiàn)。
/one.txt : ('/one', '.txt')
/one/two/three.txt : ('/one/two/three', '.txt')
/ : ('/', '')
. : ('.', '')
two.tar.gz : ('two.tar', '.gz')
commonprefix()取一個路徑列表作為參數(shù),返回一個字符串,表示所有路徑中出現(xiàn)的公共前綴。
import os.path
paths = [ '/one/two/three',
'/one/two/threetxt',
'/one/two/three/four',]
for path in paths:
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
建立路徑
除了分解現(xiàn)有路徑外,還需要從其他字符串建立路徑,使用join()。
import os.path
for parts in [ ('one', 'two', 'three'),
('\one', 'two', 'three'),
('/one', '/two', '/three', '/four'),]:
print parts, ':', os.path.join(*parts)
如果要連接的某個參數(shù)以os.sep開頭,前面所有參數(shù)都會丟棄,參數(shù)會返回值的開始部分。
('one', 'two', 'three') : one\two\three
('\\one', 'two', 'three') : \one\two\three
('/one', '/two', '/three', '/four') : /four
規(guī)范化路徑
使用join()或利用嵌入變量由單獨的字符串組合路徑時,得到的路徑最后可能會有多余的分隔符或者相對路徑部分,使用normpath()可以清除這些內(nèi)容。
import os.path
for path in [ 'one/two/three',
'one/./two/three',
'one/../alt/two/three',
]:
print '%20s : %s' % (path, os.path.normpath(path))
可以計算并壓縮有os.curdir和os.pardir構(gòu)成的路徑段。
one/two/three : one\two\three
one/./two/three : one\two\three
one/../alt/two/three : alt\two\three
要把一個相對路徑轉(zhuǎn)換為一個絕對文件名,可以使用abspath()。
import os.path
for path in [ '.',
'..',
'one/two/three',
'one/./two/three',
'one/../alt/two/three',
]:
print '%20s : %s' % (path, os.path.abspath(path))
結(jié)果是從一個文件系統(tǒng)樹最頂層開始的完整路徑。
. : 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
文件時間
import os import time print 'File:', __file__ print 'Access time:', time.ctime(os.path.getatime(__file__)) print 'Modified time:', time.ctime(os.path.getmtime(__file__)) print 'Change time:', time.ctime(os.path.getctime(__time__)) print 'Size:', os.path.getsize(__file__)
返回訪問時間,修改時間,創(chuàng)建時間,文件中的數(shù)據(jù)量。
測試文件
程序遇到一個路徑名,通常需要知道這個路徑的一些信息。
import os.path filename = r'C:\Users\Administrator\Desktop\tmp' print 'File :', filename print 'Is file? :', os.path.isfile(filename) print 'Absoulute :', os.path.isabs(filename) print 'Is dir? :', os.path.isdir(filename) print 'Is link? :', os.path.islink(filename) print 'Mountpoint? :', os.path.ismount(filename) print 'Exists? :', os.path.exists(filename) print 'Link Exists? :', os.path.lexists(filename)
所有測試都返回布爾值。
File : C:\Users\Administrator\Desktop\tmp Is file? : False Absoulute : True Is dir? : True Is link? : False Mountpoint? : False Exists? : True Link Exists? : True
遍歷一個目錄樹
import os
import os.path
import pprint
def visit(arg, dirname, names):
print dirname, arg
for name in names:
subname = os.path.join(dirname, name)
if os.path.isdir(subname):
print '%s/' % name
else:
print ' %s' % name
print
if not os.path.exists('example'):
os.mkdir('example')
if not os.path.exists('example/one'):
os.mkdir('example/one')
with open('example/one/file.txt', 'wt') as f:
f.write('i love you')
with open('example/one/another.txt', 'wt') as f:
f.write('i love you, two')
os.path.walk('example', visit, '(User data)')
會生成一個遞歸的目錄列表。
example (User data) one/ example\one (User data) another.txt file.txt
一些實際的用法合集:
#創(chuàng)建文件:
os.mknod("test.txt") 創(chuàng)建空文件
fp = open("test.txt",w) 直接打開一個文件,如果文件不存在則創(chuàng)建文件
#獲取擴展名:
>>> os.path.splitext('/Volumes/Leopard/Users/Caroline/Desktop/1.mp4')[1:]
('.mp4',)
>>> os.path.splitext('/Volumes/Leopard/Users/Caroline/Desktop/1.mp4')[1]
'.mp4'
#獲取文件名:
>>> print os.path.basename(r'/root/hahaha/123.txt')
123.txt
>>> print os.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']
#獲取文件夾大?。≒ython2.x):
import os
from os.path import join, getsize
def getdirsize(dir):
size = 0L
for root, dirs, files in os.walk(dir):
size += sum([getsize(join(root, name)) for name in files])
return size
if __name__ == '__main__':
filesize = getdirsize('/tmp')
print 'There are %.3f' % (filesize/1024/1024), 'Mbytes in /tmp'
#獲取文件夾大小(Python3.x):
import os
from os.path import join, getsize
def getdirsize(dir):
size = 0
for root, dirs, files in os.walk(dir):
size += sum([getsize(join(root, name)) for name in files])
return size
if __name__ == '__main__':
filesize = getdirsize('/tmp')
print ('There are ' + str(filesize/1024/1024) + 'Mbytes in /tmp')
相關(guān)文章
python字典setdefault方法和get方法使用實例
這篇文章主要介紹了python字典setdefault方法和get方法使用實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12
Python?數(shù)據(jù)可視化實現(xiàn)5種炫酷的動態(tài)圖
數(shù)據(jù)可以幫助我們描述這個世界、闡釋自己的想法和展示自己的成果,但如果只有單調(diào)乏味的文本和數(shù)字,我們卻往往能難抓住觀眾的眼球。而很多時候,一張漂亮的可視化圖表就足以勝過千言萬語2022-01-01
python中實現(xiàn)將多個print輸出合成一個數(shù)組
下面小編就為大家分享一篇python中實現(xiàn)將多個print輸出合成一個數(shù)組,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04

