pythonospathwalk
本文採用os.walk()和os.listdir()兩種方法,獲取指定文件夾下的文件名。
一、os.walk()
模塊os中的walk()函數可以遍歷文件夾下所有的文件。
[python] view plain
os.walk(top, topdown=Ture, onerror=None, followlinks=False)
該函數可以得到一個三元tupple(dirpath, dirnames, filenames).
參數含義:
dirpath:string,代表目錄的路徑;
dirnames:list,包含了當前dirpath路徑下所有的子目錄名字(不包含目錄路徑);
filenames:list,包含了當前dirpath路徑下所有的非目錄子文件的名字(不包含目錄路徑)。
注意,dirnames和filenames均不包含路徑信息,如需完整路徑,可使用os.path.join(dirpath, dirnames)
下面給出代碼;
[python] view plain
# -*- coding: utf-8 -*-
import os
def file_name(file_dir):
for root, dirs, files in os.walk(file_dir):
print(root) #當前目錄路徑
print(dirs) #當前路徑下所有子目錄
print(files) #當前路徑下所有非目錄子文件
當需要特定類型的文件時,代碼如下:
[python] view plain
# -*- coding: utf-8 -*-
import os
def file_name(file_dir):
L=[]
for root, dirs, files in os.walk(file_dir):
for file in files:
if os.path.splitext(file)[1] == '.jpeg':
L.append(os.path.join(root, file))
return L
其中os.path.splitext()函數將路徑拆分為文件名+擴展名,例如os.path.splitext(「E:/lena.jpg」)將得到」E:/lena「+".jpg"。
二、os.listdir()
os.listdir()函數得到的是僅當前路徑下的文件名,不包括子目錄中的文件,所有需要使用遞歸的方法得到全部文件名。
直接給出代碼,函數將返回類型為『.jpeg』個文件名:
[python] view plain
# -*- coding: utf-8 -*-
import os
def listdir(path, list_name):
for file in os.listdir(path):
file_path = os.path.join(path, file)
if os.path.isdir(file_path):
listdir(file_path, list_name)
elif os.path.splitext(file_path)[1]=='.jpeg':
list_name.append(file_path)
Ⅱ Python中如何遍歷指定目錄下的所有文件
例如:在C:\TDDOWNLOAD目錄下有a.txt、b.txt兩個文件,另有\sub1子文件夾,C:\TDDOWNLOAD\sub1下又有c.txt、d.txt兩個文件。
1. os.walk
os.walk()返回一個三元素的tuple:當前路徑、子文件夾名稱、文件列表。
>>> import os
>>> def fun( path ):
... for root, dirs, files in os.walk( path ):
... for fn in files:
... print root, fn
...
>>> fun( r'C:\TDDOWNLOAD' )
C:\TDDOWNLOAD a.txt
C:\TDDOWNLOAD b.txt
C:\TDDOWNLOAD\sub1 c.txt
C:\TDDOWNLOAD\sub1 d.txt
>>>
2. glob.glob
glob.glob()只接受一個參數,這個參數既代有路徑,又代有匹配模式,返回值為一個列表。注意,glob.glob()無法直接穿透子文件夾,需要自己處理:
>>> def fun( path ):
... for fn in glob.glob( path + os.sep + '*' ): # '*'代表匹配所有文件
... if os.path.isdir( fn ): # 如果結果為文件夾
... fun( fn ) # 遞歸
... else:
... print fn
...
>>> fun( r'C:\TDDOWNLOAD' )
C:\TDDOWNLOAD\a.txt
C:\TDDOWNLOAD\b.txt
C:\TDDOWNLOAD\sub1\c.txt
C:\TDDOWNLOAD\sub1\d.txt
>>>
'*'為匹配模式,代表匹配所有文件,只有這樣才能將子文件夾查出來,以便遞歸深入,探查下一層的文件。
Ⅲ Python中os模塊提供的與目錄相關的函數有哪些呢
答案正確。以下是這些函數的具體說明:
os.getcwd():獲取當前工作目錄的路徑名。
os.listdir(path):列出指定目錄下的所有文件和子目錄(不包含 . 和 .. 目錄)。
os.mkdir(path[, mode]):創建一個新目錄,其中 path 參數是要創建的目錄路徑名,mode 參數是可選的,指定目錄許可權,默認為 0777。
os.makedirs(path1/path2…[, mode]):遞歸創建多層目錄結構,其中 path1/path2… 參數是要創建的目錄路徑名,在這個路徑下逐層創建目錄,並且可以遞歸創建多層帶握目錄,mode 參數是可選的,指定目錄許可權,默認為 0777。
os.rmdir(path):刪除指定的目錄,前提是這個目錄必須為空,否則無法刪除。
os.removedirs(path1/path2…):遞歸刪除指定的目錄及其中的所有空目錄,其中 path1/path2… 參數是要刪除的目錄路徑名,在遞歸刪除過程中,若某個目錄不為空,則不會被刪除。
os.chdir(path):改變當前工作目錄,其中 path 參數表示要切換的目錄路徑名。
os.walk(top[, topdown[, onerror]]):以目錄樹形式遍歷指定目錄下的所有文件和子目錄,並返回一個三元組 (dirpath, dirnames, filenames),其中 dirpath 表示當前目錄路徑,dirnames 是當前目錄下的所有子目錄名,filenames 是當前目錄下的所有非目錄文件名。當 topdown 參數為 True 時,表示先遍歷一級目錄,再判斷是否需要遞歸遍歷其它子目錄,默認值為 True;當 onerror 參數不為 None 時,表示如果在遍歷目錄樹時遇到錯誤是否拋出異常(否則該錯誤直接被忽略),onerror 參數需要傳入一個函數,接受三個參數,分別是出現錯誤的根目錄、錯誤對象 Exception 和 traceback 對象。
以上是 os 模塊中的蠢正慶一些常用目錄相關函數。需要注意的是,對於一些有進行文件和目錄操作的函數,一定要清棗注意操作的許可權和路徑的正確性,避免在操作時發生不必要的錯誤。
Ⅳ python刪除目錄下的空文件夾
import os
def del_emp_dir(path):
for (root, dirs, files) in os.walk(path):
for item in dirs:
dir = os.path.join(root, item)
try:
os.rmdir(dir) #os.rmdir() 方法用於刪除指定路徑的目錄。僅當這文件夾是空的才可以, 否則, 拋出OSError。
print(dir)
except Exception as e:
print('Exception',e)
if __name__ == '__main__':
dir = r'F:\test'
del_emp_dir(dir)
Ⅳ python怎麼獲取路徑下的所有文件夾名字
import os
os.chdir("D:\\python") #設置需要查看的目錄
a = [x for x in os.listdir() if os.path.isdir(x)]
列表a裡面就是當前目錄下的文件夾名字
Ⅵ 如何獲取目錄下的文件數(一行Python)
如果想把該目錄下所有的文件都統計出來,包括子目錄、子目錄的子目錄。。。
可以使用os.walk來找出目錄下所有的文件
importos
printsum([len(x)for_,_,xinos.walk(os.path.dirname("test"))])
#test是目錄名
os.walk會遞歸遍歷指定目錄下的文件,返回值分別為當前文件夾完整路徑,當前文件夾中的文件夾和文件夾中的文件。我們只需要文件,所以其他的都不取出來了,直接使用"_"佔位就行了。
如果只是想統計出當前目錄下的文件,不包括子目錄的。就使用os.listdir,只統計是文件的個數:
len([xforxinos.listdir(os.path.dirname(__file__))ifos.path.isfile(x)])
Ⅶ python,如何遍歷一個目錄,輸出所有文件名
importos
defiterbrowse(path):
forhome,dirs,filesinos.walk(path):
forfilenameinfiles:
yieldos.path.join(home,filename)
forfullnameiniterbrowse("/home/bruce"):
printfullname