大家好,我是皮皮。
前几天在Python最强王者群【魏哥】问了一个Python自动化办公处理的问题,这里拿出来给大家分享下。
这里他自己有一个原始代码,但是实现的效果不尽人意。
import shutil import os # import sys # 导入sys模块 # sys.setrecursionlimit(1000) # 将默认的递归深度修改为3000 def copy_file(path): # (root,dirs,files)分别为:遍历的文件夹,遍历的文件夹下的所有文件夹,遍历的文件夹下的所有文件 for root, dirs, files in os.walk(path): for dir in dirs: if "数据" in dir: if "DD" in dir: # 多了一层限定条件 shutil.copyfile(root + '\\' + dir, target_path + '\\' + dir) # shutil.copytree(root + '\\' + dir, target_path + '\\' + dir) print(root + '\\' + dir + ' 复制成功-> ' + target_path) for dir_in in dirs: # for dir_in in root: copy_file(dir_in) if __name__ == '__main__': # 文件夹路径 source_path = r'D:\供应链\订单&需求单\前传小站' # 输出路径 target_path = r'C:\Users\pdcfi\Desktop\res' copy_file(source_path)
后来【eric】给了一个思路,如果一次性实现不行的话,那就分两次进行,拆分开来。思路是:第一次提取所有包含“数据”打头的文件夹,第二次,再针对获取到的“数据”的文件夹,再做一次代码处理,增加“DD”文件夹的筛选条件即可。
代码分别如下所示:第一次提取:
def copy_file(path): num = 1 # (root,dirs,files)分别为:遍历的文件夹,遍历的文件夹下的所有文件夹,遍历的文件夹下的所有文件 for root, dirs, files in os.walk(path): for dir in dirs: if "数据" in dir: shutil.copytree(root + '\\' + dir, target_path + '\\' + f"{dir}{num}") # shutil.copytree(root + '\\' + dir, target_path + '\\' + dir) print(root + '\\' + dir + ' 复制成功-> ' + target_path) num += 1 # for dir_in in dirs: # # for dir_in in root: # copy_file(dir_in) if name == 'main': # 文件夹路径 source_path = r'D:\供应链' # 输出路径 target_path = r'C:\Users\Desktop\res' copy_file(source_path)
第二次提取:
def copy_file(path): # num = 1 # (root,dirs,files)分别为:遍历的文件夹,遍历的文件夹下的所有文件夹,遍历的文件夹下的所有文件 for root, dirs, files in os.walk(path): for dir in dirs: if "DD" in dir: shutil.copytree(root + '\\' + dir, target_path + '\\' + f"{dir}") # shutil.copytree(root + '\\' + dir, target_path + '\\' + dir) print(root + '\\' + dir + ' 复制成功-> ' + target_path) # num += 1 # for dir_in in dirs: # # for dir_in in root: # copy_file(dir_in) if name == 'main': # 文件夹路径 source_path = r'C:\Users\Desktop\res' # 输出路径 target_path = r'C:\Users\Desktop\DD' copy_file(source_path)
顺利的解决了粉丝的问题:
大家好,我是皮皮。这篇文章主要盘点了一个Python自动化办公的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。
最后感谢粉丝【魏哥】提问,感谢【eric】、【瑜亮老师】给出的思路和代码解析,感谢【冫马讠成】、【冷喵】等人参与学习交流。
【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。