在Python中我们一般使用os模块来操作文件夹或文件,os为Python的内置模块,使用时直接导入即可:
import os
当目标文件夹中只有文件时,我们使用os模块的listdir()方法即可:该方法可以返回目标路径下的文件和文件夹的名字列表,参数就是目标路径。
荔枝:
文件结构如下:
def getfiles():
filenames=os.listdir(r'E:\test')
print(filenames)
结果图如下:
当目标文件中既有文件又有文件夹时,我们使用listdir()方法就只能获得第一层子文件或文件夹了,而子文件夹中的内容便获取不到了。
荔枝:
文件结构如下:
def getfiles():
filenames=os.listdir(r'E:\test2')
print(filenames)
结果如图:只显示出第一层子文件和文件夹
这时候我们需要用到os.walk()方法:传入目标路径即可。该方法可以递归的找出目表路径下的所有文件,无论他藏的有多深~
def get_files():
for filepath,dirnames,filenames in os.walk(r'E:\test2'):
for filename in filenames:
print (filename)
os.walk()方法可以生成三元组,也就是我们代码中的filepath,dirnames,filenames,我们将他们分别打印出来可以看到:
其中filepath就是目标路径下所有文件的路径:
其中dirnames是我们目标路径的所有目录名称:
其中filenames则是各个路径下的文件名称列表:
如果你足够细心的话,就会发现我们的filepath和filenames打印的结果图是一一对应的关系:文件1.txt和文件2.txt的路径就是E:\test2;文件11.txt和文件12.txt的路径就是E:\test2\目录1;以此类推。那么我们把这两个返回值拼在一起,不就是各个文件的绝对路径了么?
def get_files():
for filepath,dirnames,filenames in os.walk(r'E:\test2'):
for filename in filenames:
print(os.path.join(filepath,filename))
我们遍历目标路径下的各个文件,用os.path.join()方法将文件路径和文件名拼接在一起,就是各个文件的绝对路径了:
小提示:os.path.join()方法就是将目录和文件合成一个路径的方法。