亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python獲取文件夾下的所有文件路徑小結(jié)

 更新時間:2023年10月07日 11:19:33   作者:程序員小麥  
在Python編程過程中,需要獲取某一個文件目錄下的所有文件,或獲取文件目錄下的所有指定后綴名的文件等,本文主要介紹了Python獲取文件夾下的所有文件路徑,感興趣的可以了解一下

在Python編程過程中,我們常常有這樣的需求,需要獲取某一個文件目錄下的所有文件,或獲取文件目錄下的所有指定后綴名的文件,亦或要求獲取該文件所在的文件夾,還有可能需要替換文件名,刪除文件夾。針對這些問題,本文系統(tǒng)總結(jié)了這些方法,以供大家參考。

本實例的文件夾放置在桌面,路徑為:C:\Users\Smile\Desktop\周匯報,該文件夾下有個子文件夾,子文件夾有一個pdf文件。

1、獲取文件夾下的所有文件路徑

這里推薦使用os模塊下的listdir方法,該方法可以獲取該文件夾下的所有文件名稱(包含子文件夾名稱),之后配合os.path.join方法來獲取該文件夾下的所有文件路徑。

import os
dir_path = r'C:\Users\Smile\Desktop\周匯報'
file_ls = os.listdir(dir_path)  #獲取所有文件名稱
file_ls

運行結(jié)果如下:

我們可以發(fā)現(xiàn),結(jié)果不僅包括了文件名,還包括了子文件夾名。

獲取完整路徑,在上面基礎(chǔ)上使用1行代碼即可:

file_ls = [os.path.join(dir_path, file) for file in file_ls]
file_ls

如上圖可以發(fā)現(xiàn)獲取了指定文件夾下的所有文件路徑,還包括了子文件夾路徑。但是如果我們想要連帶獲取子文件夾下的文件名該如何操作?

解決方案就是通過os.walk方法進行。它返回3個參數(shù)——根目錄、根目錄下的所有文件、根目錄下的子文件夾。它的神奇之處在于獲取根目錄子文件夾后會繼續(xù)循環(huán),依次取出根目錄下子文件夾下的文件。

path = r'C:\Users\Smile\Desktop\周匯報'
for root, dirs, files in os.walk(path):
    print(root)

運行的結(jié)果為:

C:\Users\Smile\Desktop\周匯報
C:\Users\Smile\Desktop\周匯報\數(shù)據(jù)

可以發(fā)現(xiàn)在實驗中循環(huán)了兩次,這里指定輸出當(dāng)前循環(huán)的根目錄,第一次循環(huán)遍歷了根目錄下的文件,由于該根目錄下存在子文件夾,所以又循環(huán)了一次以獲取子文件夾下的文件,所以第二次循環(huán)輸出的根目錄為子文件夾的位置。

對此,我們可以確定,如果在循環(huán)外面指定一個空列表。在每一次循環(huán)時將文件名與根目錄進行拼接并添加到空列表中,就可以得到根目錄下所有的文件路徑。

path = r'C:\Users\Smile\Desktop\周匯報'
file_ls = []
for root, dirs, files in os.walk(path):
    root_file_ls = [os.path.join(root, file) for file in files]
    file_ls.append(root_file_ls)
file_ls

結(jié)果如下:

結(jié)果中可以看到,位于子文件夾下的文件也被添加到文件路徑列表了。

2、獲取后綴名

這里可以使用os.path.splitext方法來分割路徑,它將路徑分為兩個部分,一個是后綴名,另一個是除后綴名之外的部分。

file = r'C:\\Users\\Smile\\Desktop\\周匯報\\第六周總結(jié)_20221024_20221030.pptx'``houzhui = os.path.splitext(file)[1]``houzhui``   ``--結(jié)果--``'.pptx'

3、獲取指定后綴名的文件

路徑的本質(zhì)是字符串,可以使用endswith方法來判斷路徑是否以某個字符結(jié)尾?,F(xiàn)在將r’C:\Users\Smile\Desktop\周匯報’直接路徑下(不含子文件夾)的所有docx文件輸出。

path = r'C:\Users\Smile\Desktop\周匯報'
file_ls = []
for root, dirs, files in os.walk(path):
    root_file_ls = [os.path.join(root, file) for file in files]
    file_ls.append(root_file_ls)
#因為上面循環(huán)了兩次,第二次是子文件夾的文件,所以取出第1個元素
#使用endswith判斷是否以docx結(jié)尾
file_ls = [file for file in file_ls[0] if file.endswith('.docx')]
file_ls

結(jié)果如下:

可以看出已經(jīng)將所有的docx文件輸出。

4、修改文件名

使用os.rename(old_name, new_name)來進行。

例子我就不舉了,太累了~~~

不過要提醒一點,old_name和new_name都是路徑。

5、刪除/移動文件

刪除文件使用os.remove(路徑名)

移動文件需要使用shuilt庫,語法如下:

import shutil
shutil.move(old_name, new_name)

6、獲取文件所在的文件夾

使用os.path.dirname(path)即可獲取

path = r'C:\\Users\\Smile\\Desktop\\周匯報\\第001周總結(jié)_20220919_20220925.docx'
os.path.dirname(path)

--結(jié)果--
'C:\\\\Users\\\\Smile\\\\Desktop\\\\周匯報'

7、移除文件夾

1.如果使用os.remove(path),此時的文件夾必須是空文件夾,否則會報錯。

2.如果是非空文件夾,使用shutil.rmtree(path)即可成功刪除。

對于文件路徑的操作主要有:文件路徑獲取、后綴名獲取、獲取指定后綴名文件、刪除/移動文件、替換文件名、獲取文件所在的文件夾、移除文件夾。

到此這篇關(guān)于Python獲取文件夾下的所有文件路徑小結(jié)的文章就介紹到這了,更多相關(guān)Python獲取所有文件路徑內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Pandas JSON的處理使用

    Pandas JSON的處理使用

    Pandas提供了強大的方法來處理JSON格式的數(shù)據(jù),本文就來介紹一下Pandas JSON的處理使用,具有一定的參考價值,感興趣的可以了解一下
    2025-02-02
  • F.conv2d?pytorch卷積計算方式

    F.conv2d?pytorch卷積計算方式

    這篇文章主要介紹了F.conv2d?pytorch卷積計算方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • django settings.py配置文件的詳細介紹

    django settings.py配置文件的詳細介紹

    本文主要介紹了django settings.py配置文件的詳細介紹,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 解決Jupyter Notebook “signal only works in main thread“問題

    解決Jupyter Notebook “signal only works&nb

    這篇文章主要介紹了解決Jupyter Notebook “signal only works in main thread“問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • django 基于中間件實現(xiàn)限制ip頻繁訪問過程詳解

    django 基于中間件實現(xiàn)限制ip頻繁訪問過程詳解

    這篇文章主要介紹了django 基于中間件實現(xiàn)限制ip頻繁訪問過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • Python實現(xiàn)經(jīng)典算法拓撲排序、字符串匹配算法和最小生成樹實例

    Python實現(xiàn)經(jīng)典算法拓撲排序、字符串匹配算法和最小生成樹實例

    這篇文章主要介紹了Python實現(xiàn)經(jīng)典算法拓撲排序、字符串匹配算法和最小生成樹實例,拓撲排序、字符串匹配算法和最小生成樹是計算機科學(xué)中常用的數(shù)據(jù)結(jié)構(gòu)和算法,它們在解決各種實際問題中具有重要的應(yīng)用價值,需要的朋友可以參考下
    2023-08-08
  • Python機器學(xué)習(xí)庫之Scikit-learn基本用法詳解

    Python機器學(xué)習(xí)庫之Scikit-learn基本用法詳解

    Scikit-learn?是?Python?中最著名的機器學(xué)習(xí)庫之一,它提供了大量實用的機器學(xué)習(xí)算法以及相關(guān)的工具,可以方便我們進行數(shù)據(jù)挖掘和數(shù)據(jù)分析,在這篇文章中,我們將介紹?Scikit-learn?的基本使用,包括如何導(dǎo)入數(shù)據(jù)、預(yù)處理數(shù)據(jù)、選擇和訓(xùn)練模型,以及評估模型的性能
    2023-07-07
  • python多進程重復(fù)加載的解決方式

    python多進程重復(fù)加載的解決方式

    今天小編就為大家分享一篇python多進程重復(fù)加載的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 使用python圖形模塊turtle庫繪制櫻花、玫瑰、圣誕樹代碼實例

    使用python圖形模塊turtle庫繪制櫻花、玫瑰、圣誕樹代碼實例

    這篇文章主要介紹了用python繪制櫻花、玫瑰、圣誕樹代碼實例,需要的朋友可以參考下
    2020-03-03
  • python 去除二維數(shù)組/二維列表中的重復(fù)行方法

    python 去除二維數(shù)組/二維列表中的重復(fù)行方法

    今天小編就為大家分享一篇python 去除二維數(shù)組/二維列表中的重復(fù)行方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01

最新評論