os模块是Python标准库中整理文件和目录最为常用的模块,该模块提供了非常丰富的方法用来处理文件和目录。
os.getcwd()
>>> os.getcwd()
'D:\\ResearchWay\\Code\\PythonCode\\SparseEncoder\\DeepKSVD'
os.listdir(path)
path
路径,返回的是该路径下所有文件和目录组成的列表;>>> os.listdir(os.getcwd())
['DKSVD.py', 'load_model.py', 'main.py', 'mnist', 'save']
os.walk(path)
path
路径,深层次遍历指定路径下的所有子文件夹,返回的是一个由路径、文件夹列表、文件列表组成的元组。下面的代码用到了元组拆包。元组拆包:就是将一个元组中的每个值,赋值给不同的变量;
>>> for path, dirs, files in os.walk(os.getcwd()):
... print(path)
... print(dirs)
... print(files)
... prinprint("-" * 50)
...
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD
['mnist', 'save']
['DKSVD.py', 'load_model.py', 'main.py']
--------------------------------------------------
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD\mnist
['MNIST']
[]
--------------------------------------------------
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD\mnist\MNIST
['raw']
[]
--------------------------------------------------
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD\mnist\MNIST\raw
[]
['t10k-images-idx3-ubyte', 't10k-images-idx3-ubyte.gz', 't10k-labels-idx1-ubyte', 't10k-labels-idx1-ubyte.gz', 'train-images-idx3-ubyte', 'train-images-idx3-ubyte.gz', 'train-labels-idx1-ubyte', 'train-labels-idx1-ubyte.gz']
--------------------------------------------------
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD\save
[]
[]
--------------------------------------------------
os.path.exists(path)
path
路径,判断指定路径下的目录是否存在。存在返回True
,否则返回False
。>>> os.path.exists("D:\ResearchWay\Code\PythonCode")
True
>>> os.path.exists("D:\ResearchWay\Code\PythonCode\nihao")
False
os.mkdir(path)
path
路径,创建单层(单个)文件夹;os.path.exists(path)
函数判断文件夹是否存在;>>> if not os.path.exists(os.path.join(os.getcwd(), "hello")):
... os.mkdir(os.path.join(os.getcwd(), "hello"))
...
>>> os.listdir()
['DKSVD.py', 'hello', 'load_model.py', 'main.py', 'mnist', 'save']
os.makedirs(path)
path
路径,生成一个递归的文件夹;os.path.exists(path)
函数判断文件夹是否存在;>>> if not os.path.exists(os.path.join(os.getcwd(), "gaga/ga")):
... os.makedirs(os.path.join(os.getcwd(), "gaga/ga"))
...
>>> os.listdir()
['DKSVD.py', 'gaga', 'hello', 'load_model.py', 'main.py', 'mnist', 'save']
os.rmdir(path)
传入一个path
路径,删除指定路径下的文件夹;
注意:该方法只能删除空文件夹,删除非空文件夹会报错;
>>> os.rmdir(os.path.join(os.getcwd() + "/hello"))
>>> os.listdir()
['DKSVD.py', 'gaga', 'load_model.py', 'main.py', 'mnist', 'save']
os.path.join(path1, path2)
传入两个path
路径,将该路径拼接起来,形成一个新的完整路径;
>>> os.path.join(os.getcwd(), "1.jpg")
'D:\\ResearchWay\\Code\\PythonCode\\SparseEncoder\\DeepKSVD\\1.jpg'
>>> os.path.join(os.getcwd(), "hello")
'D:\\ResearchWay\\Code\\PythonCode\\SparseEncoder\\DeepKSVD\\hello'
os.path.split(path)
传入一个完整的path
路径,将其拆分为绝对路径和文件名两部分;
>>> os.path.split('D:\\h\\hello.jpg')
('D:\\h', 'hello.jpg')
os.path.dirname(path)
传入一个完整的文件路径,只获取其绝对路径;
>>> os.path.dirname('D:\\h\\hello.jpg')
'D:\\h'
os.path.basename(path)
传入一个完整的文件路径,只获取其文件名;
>>> os.path.basename('D:\\h\\hello.jpg')
'hello.jpg'
os.path.isdir(path)
传入一个完整的文件路径,判断它是否是文件夹;
>>> for file in os.listdir():
... if os.path.isdir(file):
... print(file)
...
gaga
mnist
save
os.path.isfile(path)
传入一个完整的文件路径,判断它是否是文件;
>>> for file in os.listdir():
... if os.path.isdir(file):
... print(file)
...
DKSVD.py
load_model.py
main.py
os.remove()
删除一个文件。
>>> os.listdir()
['DKSVD.py', 'gaga', 'load_model.py', 'main.py', 'mnist', 'readme.txt', 'save']
>>> os.remove("readme.txt")
>>> os.listdir()
['DKSVD.py', 'gaga', 'load_model.py', 'main.py', 'mnist', 'save']
os.path.sep
返回当前操作系统的路径分隔符;
>>> os.path.sep
'\\'
os.path.getsize(path)
传入一个完整的文件路径,返回该文件的大小;
>>> os.path.getsize(os.getcwd() + "/main.py")
8763
os.system()
运行shell命令。
>>> os.system('dir')
驱动器 D 中的卷是 DATA1
卷的序列号是 1879-0856
D:\ResearchWay\Code\PythonCode\SparseEncoder\DeepKSVD 的目录
2022/08/29 19:12 <DIR> .
2022/08/29 16:49 <DIR> ..
2022/04/19 20:26 8,063 DKSVD.py
2022/08/29 16:52 <DIR> gaga
2021/07/01 16:13 3,140 load_model.py
2022/04/19 20:33 8,763 main.py
2022/05/16 19:12 <DIR> mnist
2022/05/16 19:13 <DIR> save
3 个文件 19,966 字节
5 个目录 111,421,562,880 可用字节
0
os.path.abspath()
获得绝对路径。
>>> os.path.abspath("main.py")
'D:\\ResearchWay\\Code\\PythonCode\\SparseEncoder\\DeepKSVD\\main.py'
os.path.normpath(path)
规范path
字符串形式。
>>> os.path.normpath("D::/1.doc")
'D::\\1.doc'
os.path.splitext()
分离文件名与扩展名。
>>> os.path.splitext("hsdfoihjd.docx")
('hsdfoihjd', '.docx')