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