前言
我本是一位java工程师,最近不知经理受何人蛊惑,突然想到将各类excel的格式进行统一批量处理,于是我便踏上了漫长的python学习之旅~q~a~q
基本环境配置
版本:Python3
系统:Windows
相关模块:os、shutil
开发工具:Pycharm
在这里我使用的是 os,众所周知,java是最好的语言(不带针对性,各位看官切记莫急眼!)
分析需求
这几天接到一个任务,需要将一个文件夹中的多个文件夹的文件迁移到另一个文件夹里面,此时我便想到了上次做excel操作的时候所用到的os库,于是就又用上了os.path.join,用了之后才发现这串代码是真的好用,可以将获取到的文件路径进行拼接,于是就使用了递归,将其文件夹进行遍历,对遍历后的结果进行判断,如果是文件就直接移到另一个文件夹中,如果是文件夹就继续递归,最终遍历到文件为止,可参考代码如下:
代码段
import os
import shutil
# 源文件夹路径
root_path = r'C:\Users\xxx\xxx\需移动'
# 存放位置路径
new_path = r'C:\Users\xxx\xxx\存放位置'
# 遍历源文件夹中的文件和文件夹
for file_name in os.listdir(root_path):
# 拼接文件路径
file_path = os.path.join(root_path, file_name)
print(file_path)
# 判断是否为文件
if os.path.isfile(file_path):
# 如果是文件,直接复制到新目录
shutil.copy(file_path, new_path)
else:
# 如果是文件夹,遍历文件夹下的所有文件,复制到新目录
for root, dirs, files in os.walk(file_path):
for file_name in files:
sub_file_path = os.path.join(root, file_name)
shutil.copy(sub_file_path, new_path)
print(sub_file_path)