zoukankan      html  css  js  c++  java
  • 办公自动化15-一次性生成多层目录

    excel里面的目录是这样的:

    生成的目录是这样的

    代码如下:

    import os, sys
    import pandas as pd 
    
    path = 'C:/Users/17360/Desktop/cy/' 
    
    df = pd.read_excel(r'C:Users17360Desktop	est.xlsx',sheet_name= 'Sheet1')#将excel表中的文件夹名称读入DataFrame
    
    df.head()
    
    
    menu = list(df['目录'])
    for lst in menu:
        print(lst)
        num = lst.split(' ')[0]#分条件,生成文件夹
        
    if len(num.split("-")) == 2: file_name = path + str(lst) #文件夹路径 os.mkdir(file_name) #生成文件夹 if len(num.split("-")) == 3: if (len(num.split('-')[1])+len(num.split('-')[0])) == 2: pat = re.compile('^'+num[0:3]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])) == 3: pat = re.compile('^'+num[0:4]+'[^d]*[u4e00-u9fa5]+') if len(num.split('-')[1]) == 2&len(num.split('-')[0]) == 2: pat = re.compile('^'+num[0:5]+'[^d]*[u4e00-u9fa5]+') for i in menu: tem = pat.findall(i) print(tem) if len(tem)>0: file_name = path +str(tem[0]) + '/' + str(lst) #文件夹路径 os.mkdir(file_name) #生成文件夹 if len(num.split("-")) == 4: if len(num.split('-')[1]) == 1: pat = re.compile('^'+num[0:3]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])) == 3: pat = re.compile('^'+num[0:4]+'[^d]*[u4e00-u9fa5]+') if len(num.split('-')[1]) == 2&len(num.split('-')[0]) == 2: pat = re.compile('^'+num[0:5]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])+len(num.split('-')[2])) == 3: pat1 = re.compile('^'+num[0:5]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])+len(num.split('-')[2])) == 4: pat1 = re.compile('^'+num[0:6]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])+len(num.split('-')[2])) == 5: pat1 = re.compile('^'+num[0:7]+'[^d]*[u4e00-u9fa5]+') if (len(num.split('-')[1]) + len(num.split('-')[0])+len(num.split('-')[2])) == 6: pat1 = re.compile('^'+num[0:8]+'[^d]*[u4e00-u9fa5]+') for i in menu: tem = pat.findall(i) if len(tem)>0: s1 = tem print(s1) for i in menu: tem1 = pat1.findall(i) if len(tem1)>0: s2 = tem1 print(s2) file_name = path +str(s1[0])+'/'+str(s2[0]) + '/' + str(lst) #文件夹路径 os.mkdir(file_name) #生成文件夹

    有问题欢迎提问哦~~~^_^

  • 相关阅读:
    String substring(int start,int end)截取当前字符串中指定范围内的字符串
    String字符串是不变对象,内容一旦创建不可改变,若改变一定会创建新对象
    StringBuilder修改字符串内容,增,删,改,插
    startsWith(),endsWith()判断当前字符串是否是以给定字符串开始或结尾的
    length()返回当前字符串的字符个数
    indexOf()字符位置
    charAt()检测回文
    手把手教你猜字小游戏
    release 和 drain
    c专家编程 ,c语言运行时环境
  • 原文地址:https://www.cnblogs.com/lizitingxue/p/12623201.html
Copyright © 2011-2022 走看看