os.walk 遍歷目錄下目錄和檔案
python中os.walk是一個簡單易用的檔案、目錄遍歷器,可以幫助我們高效的處理檔案、目錄方面的事情。
1.載入
要使用os.walk,首先要載入該函式
可以使用以下兩種方法
import os
from os import walk
2.使用
os.walk的函式宣告為:
walk(top, topdown=True, onerror=None, followlinks=False)
引數
top 是你所要便利的目錄的地址
topdown 為真,則優先遍歷top目錄,否則優先遍歷top的子目錄(預設為開啟)
onerror 需要一個 callable 物件,當walk需要異常時,會呼叫
followlinks 如果為真,則會遍歷目錄下的快捷方式(linux 下是 symbolic link)實際所指的目錄(預設關閉)
os.walk 的返回值是一個生成器(generator),也就是說我們需要不斷的遍歷它,來獲得所有的內容。
每次遍歷的物件都是返回的是一個三元組(root,dirs,files)
root 所指的是當前正在遍歷的這個資料夾的本身的地址
dirs 是一個 list ,內容是該資料夾中所有的目錄的名字(不包括子目錄)
files 同樣是 list , 內容是該資料夾中所有的檔案(不包括子目錄)
如果topdown 引數為真,walk 會遍歷top資料夾,與top資料夾中每一個子目錄。
例子:
from os import walk
import pandas as pd
dataframe_list = []
#walk會返回3個引數,分別是路徑,目錄list,檔案list,你可以按需修改下
for f, _, i in walk(“E:\names”):
for j in i:
dataframe_list.append(pd.read_csv(f + “\” + j))
# coding=utf-8
import os
mypath = "C:\\Users\\LiLong\\Desktop\\tt"
for root , dirs, files in os.walk(mypath):
print(root)
print(dirs)
print(files)
print('..................................................')
for root,dirs,files in os.walk(mypath):
print(root)
for dr in dirs:
print (dr)
for name in files:
if name.endswith(".txt"):
print(os.path.join(root, name))
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
執行結果:
從結果可以看出遍歷的流程
參考:> http://www.jianshu.com/p/bbad16822eab
python中os.walk是一個簡單易用的檔案、目錄遍歷器,可以幫助我們高效的處理檔案、目錄方面的事情。