【办公自动化实例】在excel中创建目录后使用python批量生成多级文件夹

文章目录

        • 一、需求
        • 二、处理方式
        • 三、代码实现

一、需求

在excel中先创建目录,然后使用python批量生成多级文件夹。如图:
【办公自动化实例】在excel中创建目录后使用python批量生成多级文件夹_第1张图片

二、处理方式

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('文件夹已存在')

你可能感兴趣的:(办公自动化,python,pandas,开发语言)