Python-多任务复制文件夹
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-多任务复制文件夹的更多相关文章
- JAVA实现复制文件夹
package com.filetest; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; impor ...
- CMD复制文件夹
CMD复制文件夹 xcopy /E/I/Y "D:\GitHub\WIP\app" "D:\GitHub\WIP_server\html\webshell"
- Web 在线文件管理器学习笔记与总结(13)重命名文件夹(14)复制文件夹
(13)重命名文件夹 ① 重命名文件夹通过 rename($oldname,$newname) 实现 ② 检测文件夹名是否符合规范 ③ 检测当前目录中是否存在同名文件夹名称,如果不存在则重命名成功 i ...
- c# 封装的文件夹操作类之复制文件夹
c# 封装的文件夹操作类之复制文件夹 一.复制文件夹原理: 1.递归遍历文件夹 2.复制文件 二.FolderHelper.cs /// <summary> /// 文件夹操作类 /// ...
- java复制文件夹中的所有文件和文件夹到另一个文件夹中
1.复制文件夹 public static void copyDir(String oldPath, String newPath) throws IOException { File file = ...
- Python新建/删除文件夹
新建以当前日期为名的文件夹 import datetime,os,shutil today = datetime.datetime.now().date().strftime('%Y%m%d') pa ...
- PHP复制文件夹及文件夹内的文件
//1.取被复制的文件夹的名字://2.写出新的文件夹的名字://3.调用此函数,将旧.新文件夹名字作为参数传递://4.如需复制文件夹内的文件,第三个参数传1,否则传0: public functi ...
- linux cp 复制文件夹
复制文件夹需要添加 -r 或 -R 参数(recursive: 递归的:循环的) 如 cp -r DIR_A DIR_B; 同理,rm 也一样. 如 rm -r DIR_B
- java复制文件夹及所有子目录和文件
package text; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; im ...
- C# 压缩 解压 复制文件夹,文件的操作
命名空间:namespace System.IO.Compression 压缩: //目标文件夹 string fileDirPath = "/Downloads/试题" + us ...
随机推荐
- c2000 N2A1 设置 KonNaD Settings & User Manual
KonNaD Settings & User Manual c2000 N2A1 两个开关都推到左边,都设置成off
- gbdt在回归方面的基本原理以及实例并且可以做分类
对书法的热爱,和编译器打数学公式很艰难,就这样的正例自己学过的东西,明天更新gbdt在分类方面的应用. 结论,如果要用一个常量来预测y,用log(sum(y)/sum(1-y))是一个最佳的选择. 本 ...
- 第2章 ZooKeeper安装与启动
第2章 ZooKeeper安装 2-1 JDK的安装 需要先在Linux系统下安装JDK1.8 tar -zxvf jdk-8u231-linux-x64.tar.gz rm -f jdk-8u231 ...
- Cannot read property 'XXXX' of null/undifined
这个问题可能的原因有很多 1.如果你的js直接写在自执行函数或者head标签内的script里面,那么可以检查一下你的代码有没有用到页面里的节点,因为这样写的代码在页面加载完成之前就会开始执行,如果有 ...
- 第2章 Innodb 存储引擎
一.InnoDB 体系架构 1.1后台线程 master thread:刷新内存中的数据到磁盘 io thread:处理 IO 请求,AIO purge thread:清理undo 页的回收 page ...
- [USACO09DEC]音符Music Notes (二分、STL)
https://www.luogu.org/problem/P2969 题目描述 FJ is going to teach his cows how to play a song. The song ...
- 9.数据分组 group by
--数据分组 group by --作用:用于 对查询的数据进行分组,并处理 select deptno,job from emp group by deptno,job --1.分组之后,不能将除分 ...
- Maven 仓库搜索服务和私服搭建
Maven 仓库搜索服务 使用maven进行日常开发的时候,一个常见问题就是如何寻找需要的依赖,我们可能只知道需要使用类库的项目名称,但是添加maven依赖要求提供确切的maven坐标,这时就可以使用 ...
- day29-struct模块解决黏包问题
#struct模块可以把一个数据类型,例如数字int,转化成固定长度(4个字节)的bytes.int转为4个bytes. #在大量传输数据之前先告诉接收端即将接收数据的大小,方可解决黏包问题: #利用 ...
- sequelize 应用hook 实现对分表的访问
https://github.com/cclient/sequelize-shardinghttps://www.npmjs.com/package/sequelize-sharding 实际有效的代 ...