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