溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用python遞歸算法查找文件

發(fā)布時(shí)間:2020-11-13 09:34:47 來源:億速云 閱讀:174 作者:小新 欄目:編程語言

這篇文章主要介紹如何使用python遞歸算法查找文件,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

使用python構(gòu)建遞歸算法,實(shí)現(xiàn)查找電腦中的所有文件

需要檢測一個(gè)大文件夾下所有文件的更新狀態(tài),這個(gè)大文件夾下面包含了很多文件和文件夾,文件夾中又包含了很多文件和文件夾等等。

這么多層的包含嵌套關(guān)系,首先想到的可能是使用for循環(huán),但是在這個(gè)需求中,for循環(huán)不能滿足我們的要求,原因有兩個(gè):

我不能確定文件夾中到底嵌套了多少層

使用for循環(huán)為增加代碼量并且不好維護(hù)

遞歸算法

通俗的解釋是后一步需要依據(jù)前一步的結(jié)果來進(jìn)行,所以我們可以定義一個(gè)函數(shù),在滿足條件的是的在函數(shù)內(nèi)部調(diào)用這個(gè)函數(shù)。

我們先來看python代碼:

file_list = []
def get_file_url(session, next_url):
 next_response = session.get('https://gitlab.com' + next_url)
 soup = BeautifulSoup(next_response.text, 'html.parser')
 folders = soup.find_all('tr', class_=re.compile("^tree-item file_"))
 for folder in folders:
 folder_name = folder.find('td').find('a').attrs['title']
 folder_url = folder.find('td').find('a').attrs['href']
 
 if len(folder_name.split('.')) > 1:
 file_list.append(folder_url)
 else:
 get_file_url(session, folder_url)

以上是如何使用python遞歸算法查找文件的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI