本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,基于其中每一个文件的名称,从另一个文件夹中找到与这一文件夹中文件同名的文件,并将找到的同名文件复制到第三个文件夹中的方法。
首先,我们来明确一下本文的具体需求。现有一个文件夹,其中有大量的Excel表格文件(在本文中我们就以csv
格式的文件为例)——这一文件夹中的文件其实也就是我们通过文章Python遍历大量表格文件并筛选出表格内数据缺失率低的文件(https://blog.csdn.net/zhebushibiaoshifu/article/details/130714834)筛选得到的文件;如下图所示。
此外,我们还有一个文件夹(我们将其称作大文件夹),其中存放了较之上图所示的文件夹中,更多的Excel表格文件;我们希望实现的是,从这个大文件夹中,找到与上图所示文件夹中Excel表格文件同名的文件,并将找到的同名文件复制到另一个新的文件夹中。
知道了需求,我们就可以开始代码的撰写。其中,本文用到的代码如下所示。
# -*- coding: utf-8 -*-
"""
Created on Tue May 16 22:32:00 2023
@author: fkxxgis
"""
import os
import shutil
def copy_file_with_name(source_path, target_path, new_path):
source_file = os.listdir(source_path)
for file in source_file:
target_file_path = os.path.join(target_path, file)
if os.path.isfile(target_file_path):
new_file_path = os.path.join(new_path, file)
shutil.copy(target_file_path, new_file_path)
copy_file_with_name("E:/01_Reflectivity/99_Model_Training/00_Data/02_Extract_Data/14_PointSelection/LowMissingRate",
"E:/01_Reflectivity/99_Model_Training/00_Data/02_Extract_Data/13_AllYearAverage",
"E:/01_Reflectivity/99_Model_Training/00_Data/02_Extract_Data/15_8DaysSynthesis")
上述这段代码中,我们首先导入了os
和shutil
模块,os
模块用于处理文件和文件夹的操作,shutil
模块用于执行文件的复制操作。然后定义了一个名为copy_file_with_name
的函数,该函数接受3
个参数:source_path
表示源文件夹路径,target_path
表示目标文件夹(也就是上面提到的大文件夹)路径,new_path
表示新的文件夹路径。source_file = os.listdir(source_path)
获取源文件夹中的所有文件,并将文件列表赋值给source_file
。
在接下来的这个循环中,对于源文件夹中的每个文件,我们构建目标文件的完整路径target_file_path
,其中target_path
是目标文件夹的路径,file
是源文件夹中的文件名。然后使用os.path.isfile(target_file_path)
检查目标文件是否存在,如果存在则执行下一步操作。接下来,我们构建新文件的完整路径new_file_path
,其中new_path
是新文件夹的路径,file
是源文件夹中的文件名。最后,使用shutil.copy
函数将目标文件复制到新文件夹中。
最后一行代码调用了copy_file_with_name
函数,传入了三个文件夹的路径作为参数,从一个文件夹中复制文件到另一个文件夹中。
运行上述代码后,我们即可在new_path
这一文件夹中,找到我们复制好的文件;其中,很显然new_path
这一文件夹的文件数量与source_path
文件夹中的文件数量是一致的。
至此,大功告成。文章来源:https://www.toymoban.com/news/detail-448125.html
欢迎关注:疯狂学习GIS文章来源地址https://www.toymoban.com/news/detail-448125.html
到了这里,关于Python依据某一文件夹中大量文件的名称复制另一文件夹中的同名文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!