侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

python2.7实现复制大量文件及文件夹资料

Python  /  管理员 发布于 7年前   190

需求:拷大量数据,发现有2000G,靠系统的复制功能怕是得好几个小时,于是回来学一手操作,话不多说上代码:

说明:CopyFiles1是可以将sourceDir连子目录一起原样复制到targetDir,而CopyFiles2是在sourceDir中筛选特定格式文件,然后将其直接放在targetDir中,会很乱。但是很快

import osimport timeimport shutilsourceDir = r"D:\copytest\datatest"targetDir = r"D:\copytest\result"copyFileCounts = 0 def CopyFiles1(sourceDir, targetDir):#完全连子目录也会复制好,美观 global copyFileCounts print(sourceDir ) print("%s 当前处理文件夹%s已处理%s 个文件" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), sourceDir,copyFileCounts) ) for f in os.listdir(sourceDir):  sourceF = os.path.join(sourceDir, f)  targetF = os.path.join(targetDir, f)   if os.path.isfile(sourceF):    if not os.path.exists(targetDir):    os.makedirs(targetDir)   copyFileCounts += 1     if not os.path.exists(targetF) or (os.path.exists(targetF) and (os.path.getsize(targetF) != os.path.getsize(sourceF))):     open(targetF, "wb").write(open(sourceF, "rb").read())    print ("%s %s 复制完毕" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), targetF))   else:    print ("%s %s 已存在,不重复复制" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), targetF))   if os.path.isdir(sourceF):   copyFiles(sourceF, targetF) def CopyFiles2(dir): #会将目录下所有文件都复制在一起,速度快,可以筛选文件 i=0 for root,dir1,filename in os.walk(dir):  #print(filename)  for index in range(len(filename)):  #print(os.path.splitext(filename[index])[1])  #if os.path.splitext(filename[index])[1]=='.':#这里注意filename是个元组,splitext方法的时候只能是字符串  if 1==1:   #i+=1   print('here')   root1="D:\\copytest\\result3"   old_path = os.path.join(root, filename[index])   print(old_path)   new_path = os.path.join(root1,filename[index])   shutil.copyfile(old_path,new_path) #print("总共有",i,"图层文件被复制!") if __name__ == "__main__": time_start = time.time() try: import psyco psyco.profile() except ImportError:  pass #CopyFiles1(sourceDir,targetDir) CopyFiles2("D:/copytest/datatest") time_end = time.time() print('totally cost', time_end - time_start) #实战代码#!/usr/bin/python2# coding=UTF-8#@author neo_will#version 2019-04-02 10:39 import osimport os.pathimport shutilimport time, datetime #fpath_2018 = [1207, 1121, 1120, 1119, 1112, 1101, 1025, 1009, 0704, 0608, 0531, 0530, 0517, 0502, 0418, 0330, 0201, 0131]#sourceDir=r"F:\LEVEL2_shanghai\2018\fpath_2018[0:]"#des_dir=r"G:\MarketDataSupplement\shanghai\2018\fpath_2018[0:]"#原始目录和拷贝到的目录地址sourceDir = r"D:\tools\wj"targetDir = r"D:\Users\wj"copyFileCounts = 0 #定义拷贝文件的函数def copyFiles(sourceDir, targetDir): global copyFileCounts print (sourceDir ) print ("%s 当前处理文件夹%s已处理%s 个文件" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), sourceDir,copyFileCounts) ) for f in os.listdir(sourceDir): sourceF = os.path.join(sourceDir, f) targetF = os.path.join(targetDir, f) if os.path.isfile(sourceF): #创建目录 if not os.path.exists(targetDir): os.makedirs(targetDir) copyFileCounts += 1  #文件不存在的话,或者存在但是大小存在差异不同,执行完全覆盖操作 if not os.path.exists(targetF) or (os.path.exists(targetF) and (os.path.getsize(targetF) != os.path.getsize(sourceF))): #二进制文件 open(targetF, "wb").write(open(sourceF, "rb").read()) print u"%s %s copy over" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), targetF) else:  print("%s %s is exists,please don't copy more" %(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())), targetF))  if os.path.isdir(sourceF): copyFiles(sourceF, targetF) if __name__ == "__main__": time_start = time.time() try: import psyco psyco.profile() except ImportError: pass #copyFiles(sourceDir,targetDir) copyFiles(r"D:\tools\wj",r"D:\Users\wj") time_end = time.time() print('totally cost', time_end - time_start) 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    python输出带颜色字体实例方法
    下一条:
    python3实现高效的端口扫描
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客