一.os.path.join
os.path.join()函数用于路径拼接文件路径,可以传入多个路径
如果不存在以“/”开始的参数,则函数会自动加上
>>> import os
>>> print(os.path.join('path','abc','yyy'))
path\abc\yyy
存在以“/”开始的参数,从最后一个以“/”开头的参数开始拼接,之前的参数全部丢弃
>>> print('1',os.path.join('aaa','/bbb','ccc.txt'))
1 /bbb\ccc.txt
>>> print('1',os.path.join('/aaa','/bbb','ccc.txt'))
1 /bbb\ccc.txt
>>> print('1',os.path.join('/aaa','/bbb','/ccc.txt'))
1 /ccc.txt
>>> print('1',os.path.join('/aaa','bbb','ccc.txt'))
1 /aaa\bbb\ccc.txt
>>> print('1',os.path.join('/aaa','bbb','/ccc.txt'))
1 /ccc.txt
同时存在以“./”与“/”开始的参数,以“/”为主,从最后一个以“/”开头的参数开始拼接,之前的参数全部丢弃。
>>> print('2',os.path.join('/aaa','./bbb','ccc.txt'))
2 /aaa\./bbb\ccc.txt
>>> print('2',os.path.join('aaa','./bbb','/ccc.txt'))
2 /ccc.txt
只存在以‘’./’开始的参数,会从”./”开头的参数的上一个参数开始拼接。
>>> print('2',os.path.join('aaa','./bbb','ccc.txt'))
2 aaa\./bbb\ccc.txt
注意
二.os.path.exists
os.path模块主要用于文件的属性获取,exists是“存在”的意思,所以顾名思义,os.path.exists()就是判断括号里的文件是否存在的意思,括号内的可以是文件路径。
三.os.walk
用os.walk扫描test文件夹下所有的子目录和文件:
# 使用os.walk扫描目录
import os
for curDir, dirs, files in os.walk("test"):
print("====================")
print("现在的目录:" + curDir)
print("该目录下包含的子目录:" + str(dirs))
print("该目录下包含的文件:" + str(files))
上面的代码在扫描子目录和文件的时候,是采用自顶向下的方式进行扫描。如果想要自底向上地扫描子目录和文件,可以添加上topdown=False参数:
重点注意分清楚,当前目录,子目录以及当前目录下的文件
四.os.makedirs(“路径”)
创建该目录
五.shutil.rmtree()
表示递归删除文件夹下的所有子文件夹和子文件。
因此如果想删除E盘下某个文件夹,可以用
shutil.rmtree('E:\\myPython\\image-filter\\test', ignore_errors=True)
这样 test 文件夹内的所有文件(包括 test 本身)都会被删除,并且忽略错误。
六.glob.glob()
python的glob模块可以对文件夹下所有文件进行遍历,并保存为一个list列表
Path = "./map_out" GT_PATH=os.path.join(Path, "ground-truth") ground_truth_files_list = glob.glob(GT_PATH + '/*.txt') print(ground_truth_files_list)
['./map_out\\ground-truth\\car_net_111.txt', './map_out\\ground-truth\\car_net_112.txt', './map_out\\ground-truth\\car_net_120.txt', .....]