import multiprocessing
import os
import time def copy_file(queue, file_name, old_folder_name, new_folder_name, count):
"""完成文件的复制"""
# 拼凑包含完整路径的文件(夹)
# os.path.join 把目录和文件名合成一个路径
old_file_name = os.path.join(old_folder_name, file_name)
new_file_name = new_folder_name + "/" + file_name
if os.path.isdir(old_file_name):
os.mkdir(new_folder_name + "/" + file_name)
f_names = os.listdir(old_file_name)
for f_name in f_names:
copy_file(queue, f_name, old_file_name, new_file_name, count)
# 进程池中出错,没有显示
# print("%s复制中...." % file_name)
else:
old_f = open(old_file_name, 'rb')
new_f = open(new_file_name, 'wb')
new_f.write(old_f.read())
old_f.close()
new_f.close()
count[0] += 1
# 如果拷贝完了文件,那么就向队列中写入一个消息,表示已经完成
queue.put(file_name) def get_files_num(top):
"""获取文件夹及子文件夹的个数"""
file_count = 0
for root, dirs, files in os.walk(top, topdown=False):
for name in files:
file_count += 1
return file_count def rmdirs(top):
for root, dirs, files in os.walk(top, topdown=False):
# 先删除文件夹
for name in files:
os.remove(os.path.join(root, name))
# 再删除空目录
for name in dirs:
os.rmdir(os.path.join(root, name))
# for循环执行后top就为空目录
# 如果要删除将下面的注释打开
# os.rmdir(top) def main():
# 1 获取用户要copy的文件夹的名字
old_folder_name = input("请输入要复制的文件夹的名字:")
# 2 创建一个新的文件夹
try:
new_folder_name = old_folder_name + "[副本]"
os.mkdir(new_folder_name)
except:
# os.removedirs(new_folder_name)
# 先删除目录
rmdirs(new_folder_name)
# 3 获取文件夹所有的待copy的文件名字 listdir
file_names = os.listdir(old_folder_name)
# 4 创建进程池
pool = multiprocessing.Pool(5)
# 5 创建队列 显示复制的进度
queue = multiprocessing.Manager().Queue()
# 主进程与子进程共享这个List
count = multiprocessing.Manager().list([0])
# 6 向进程池中添加复制文件的任务
for file_name in file_names:
# 复制原文件夹中的文件, 到新文件夹中的文件去
pool.apply_async(copy_file, args=(queue, file_name, old_folder_name, new_folder_name, count))
# copy_file(queue, file_name, old_folder_name, new_folder_name, count)
pool.close()
pool.join()
# count[0] 要等到进程结束才有值
# 所有文件的长度
all_file_num = get_files_num(old_folder_name)
# 复制成功的长度
while True:
# file_name = queue.get()
# print("已经完成复制: %s " % file_name) # print(queue.qsize())
time.sleep(0.1)
print("\r复制进度.. %.2f%% " % (queue.qsize() * 100 / all_file_num), end="")
if all_file_num == queue.qsize():
print("")
exit()
# if all_file_num == count[0]:
# print("")
# exit() if __name__ == "__main__":
main()

  这里使用两种方式来记录的进度

  第一种:使用进程之间的共享变量

 count = multiprocessing.Manager().list([0])

  第二种:使用队列的方式来记录

# 创建队列
queue = multiprocessing.Manager().Queue() # 获取队列的长度
queue.qsize() # 入队列
queue.put()

  注: 显示复制的进度未完善,即使加了延时

Python-多任务复制文件夹的更多相关文章

  1. JAVA实现复制文件夹

    package com.filetest; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; impor ...

  2. CMD复制文件夹

    CMD复制文件夹 xcopy /E/I/Y "D:\GitHub\WIP\app" "D:\GitHub\WIP_server\html\webshell"

  3. Web 在线文件管理器学习笔记与总结(13)重命名文件夹(14)复制文件夹

    (13)重命名文件夹 ① 重命名文件夹通过 rename($oldname,$newname) 实现 ② 检测文件夹名是否符合规范 ③ 检测当前目录中是否存在同名文件夹名称,如果不存在则重命名成功 i ...

  4. c# 封装的文件夹操作类之复制文件夹

    c#  封装的文件夹操作类之复制文件夹 一.复制文件夹原理: 1.递归遍历文件夹 2.复制文件 二.FolderHelper.cs /// <summary> /// 文件夹操作类 /// ...

  5. java复制文件夹中的所有文件和文件夹到另一个文件夹中

    1.复制文件夹 public static void copyDir(String oldPath, String newPath) throws IOException { File file = ...

  6. Python新建/删除文件夹

    新建以当前日期为名的文件夹 import datetime,os,shutil today = datetime.datetime.now().date().strftime('%Y%m%d') pa ...

  7. PHP复制文件夹及文件夹内的文件

    //1.取被复制的文件夹的名字://2.写出新的文件夹的名字://3.调用此函数,将旧.新文件夹名字作为参数传递://4.如需复制文件夹内的文件,第三个参数传1,否则传0: public functi ...

  8. linux cp 复制文件夹

    复制文件夹需要添加 -r 或 -R 参数(recursive: 递归的:循环的) 如 cp -r DIR_A DIR_B; 同理,rm 也一样. 如 rm -r DIR_B

  9. java复制文件夹及所有子目录和文件

    package text; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; im ...

  10. C# 压缩 解压 复制文件夹,文件的操作

    命名空间:namespace System.IO.Compression 压缩: //目标文件夹 string fileDirPath = "/Downloads/试题" + us ...

随机推荐

  1. LIINQ TO JS

    记录一下,方便自己查找... 自己在开发前端时,对于处理JSON,觉得真是枯燥.处理数据,基本都要循环. 所以我想着前端也能跟后端一样,有Linq来处理我的JSON对象就好了.上网一搜,找到了JSLI ...

  2. 17.3.12--urllib2模块

    1---urllib2是非常强大的Python网络资源访问模块,它的功能和urllib模块相似 python标准库中的urllib2模块可以说是urlib模块的一个升级的复杂版,不需要另外下载, 比如 ...

  3. OpenVINO在linux下安装

    一.准备安装环境: 1.带命令行的64位centos操作系统,推荐极简安装模式,先不要安装GNOME桌面,避免和后面的openvino环境冲突 2.cpu要求 我目前是在服务器的虚拟机里面安装 注意如 ...

  4. [原]你知道怎么使用DebugView查看内核调试信息吗?

    原总结注册表sysinternalsdebugviewprocess explorerprocess monitor 简介 DebugView是sysinternals工具集中的一款用来查看调试信息的 ...

  5. win10 python 3.7 pip install tensorflow

    环境: ide:pyCharm 2018.3.2 pyhton3.7 os:win10 64bit 步骤: 1.确认你的python有没有装pip,有则直接跳2.无则cmd到python安装目录下ea ...

  6. 使用Anaconda安装TensorFlow

    conda create -n tensorflow python=2.7 # or python=3.3, etc. pip install --ignore-installed --upgrade ...

  7. placeholder在IE下的兼容问题

    最近写项目要求兼容到ie8,写完了去ie测试的时候,发现了placeholder在ie下的兼容问题,为了解决,搜罗网上各种牛人的解决方案,自己总结如下: css样式(设置各浏览器下placeholde ...

  8. uniapp结合小程序第三方插件“WechatSI”实现语音识别功能,进而实现终端控制

    最近在用soket实现终端控制器的功能,然后就想用语音控制,这样显得更AI WechatSI在manifest.json中配置: 在vue中插入如下展示代码: <view class=" ...

  9. Docker Compose文件详解 V2

    Compose file reference 语法: web:      build: ./web      ports:      - "5000:5000"      volu ...

  10. Drools规则引擎详解-常用的drl实例

    package droolsDemo //说明:每个 drl 都必须声明一个包名,这个包名与 Java 里面的不同,它不需要与文件夹的层次结构一致, //主要用于可以根据kmodule.xml中不同的 ...