os.makedir(path)和os.makedirs(path)
今天工作中将hadoop文件同步到服务器磁盘,由于文件类别目录较多,迁移文件时需要判断是否存在
这里有两个方法os.mkdir(path)和os.makedirs(path)
os.mkdir(path)
他的功能是一级一级的创建目录,前提是前面的目录已存在,如果不存在会报异常,比较麻烦,但是存在即有他的道理,当你的目录是根据文件名动态创建的时候,你会发现他虽然繁琐但是很有保障,不会因为你的一时手抖,创建而创建了双层或者多层错误路径,
1
2
3
4
5
6
|
import os os.mkdir( 'd:\hello' ) # 正常 os.mkdir( 'd:\hello\hi' ) # 正常 # 如果d:\hello目录不存在 # 则os.mkdir('d:\hello\hi')执行失败 |
os.makedirs(path)
单从写法上就能猜出他的区别,他可以一次创建多级目录,哪怕中间目录不存在也能正常的(替你)创建,想想都可怕,万一你中间目录写错一个单词.........
1
2
3
4
5
6
|
import os os.makedirs( 'd:\hello' ) # 正常 os.makedirs( 'd:\hello\hi' ) # 正常 # 如果d:\hello目录不存在 # 则os.makedirs('d:\hello\hi') # 仍然正常 |
各有优缺点,根据自己需要选择使用。
补充:Python中os.path和os.makedirs的运用(判断文件或文件夹是否存在,创建文件夹)
1
2
3
4
5
6
7
8
9
10
11
12
|
import os import numpy as np data = np.array([ 1 , 2 , 3 ]) if not os.path.exists( "./data/" ): print ( "# path not exists" ) os.makedirs( "./data/" ) if not os.path.exists( "./data/data.npy" ): print ( "# data.npy not exists" ) np.save( "./data/data.npy" , data) print ( "# path exists? :" , os.path.exists( "./data/" )) print ( "# data.npy exists? :" , os.path.exists( "./data/data.npy" )) |
运行结果:
1
2
3
4
|
# path not exists # data.npy not exists # path exists? : True # data.npy exists? : True |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/Beyond_F4/article/details/80430911