一、需求
在excel中先创建目录,然后使用python批量生成多级文件夹。如图:
二、处理方式
1、先在excel 文件中,创建好相关的文件层级;
2、通过pandas读取excel文件,并做相应处理;
3、通过os模块创建多层文件夹。
注:
1、python版本 3.8
三、代码实现
import os
import pandas as pd
def merge_dir(x,fill_dir):
'''
删除空路径下的文件夹
'''
try:
n = str(x).split('/').index(fill_dir) # 定位空文件夹所在位置
x = '/'.join(str(x).split('/')[0:n]) # 删除空文件夹的路径
except Exception as e:
print(e)
return str(x)
df=pd.read_excel('文件夹目录.xlsx')
#列中有空值的,直接合并不行,需要做一次处理。
df = df.fillna('空文件夹')
col = df.columns
n = len(df.columns)
df['all'] = df[col[1]].astype('str') # 如果需要写绝对路径,这里可参考修改为"'d:/' + df[col[1]]"
for i in range(2,n):
df['all'] = df['all'] + '/' + df[col[i]].astype('str')
df['all'] = df['all'].apply(merge_dir,args=('空文件夹',)) #注意,这里args参数里面如果只有一个参数,需要加入一个括号
# 使用os模块的makedirs创建多层文件夹
for f_dir in df['all'].to_list():
if not os.path.exists(f_dir):
os.makedirs(f_dir)
print(f'已完成路径:{f_dir} 下所有文件夹的创建')
else:
print('文件夹已存在')