处理数据有时候为了方便,可能需要将所有待处理文件复制一份到新的文件夹。如果待复制文件在同一文件夹下,通过鼠标选择也可以接受,但是如果不在同一文件夹下,重复的打开、复制、关闭、黏贴,文件数量一旦很多,想想也让人头疼。
Python实现文件的批量复制需要两个步骤:找到文件,然后复制文件。对应的需要用到pathlib和shutil两个库,pathlib用于寻找目标文件,shutil用于复制文件。具体实现代码如下:
注:关于pathlib库寻找目标文件的实现方式在我的上一篇文章中已经说明,感兴趣的的同学可以看一下
import shutil
from pathlib import Path
def object_files(files_path, key_word):
"""找出目标文件"""
p = Path(files_path)
fullname = [] # 存储指定类型所有文件名
for file in p.rglob('*.txt'): # 遍历指定文件夹所有指定类型文件
fullname.append(str(file))
files = [] # 所有目标文件名
for i in fullname:
if key_word in i:
files.append(i)
return files
files_path = r'E:\Desktop\数据集\全部数据' # 所有目标文件所在的公共原始文件夹
key_word = '行走' # 目标文件包含的关键字
dst = r'E:\Desktop\数据集\行走数据' # 复制到目标文件夹
files = object_files(files_path, key_word) # 找出所有的目标文件
for i in files:
# 若想文件保持原文件夹结构,需根据每个文件名新建对应的文件夹
p = Path(dst+i[19::]) # 拼接路径:目标文件夹+原始文件结构 创建Path对象
p.parents[1].mkdir(parents=True, exist_ok=True) # 创建上一级目录文件夹
# 若无此需求,直接复制到指定文件夹即可
shutil.copy(i, p.parents[1]) # 复制文件
作者水平有限,文中若有错误望大家指出,共同学习,共同进步