import multiporcessing
import os
import time
import random
def copy_file(queue,file_name,source_folder_name,dest_folder_name):
f_read = open(source_folder_name + “/” + file_name, “rb”)
f_write = open(dest_folder_name + “/” + file_name, “wb”)
while True:
time.sleep(random.random())
content = f_read.read(1024)
if content:
f_write.write(content)
else:
break
f_read.close()
f_write.close()
def main():
source_folder_name = input(“请输入要复制的文件夹的名字:”)
dest_folder_name = source_folder_name + “[副本]”
try:
os.mkdir(dest_folder_name)
except:
pass
file_names = os.listdir(source_folder_name)
queue = multiprocessing.Manger().Queue()
pool = multiprocessing.Pool(3)
for file_name in file_names:
pool.apply_async(copy_file, args=(queue,file_name,source_folder_name,dest_folder_name))
pool.close()
while True:
if not queue.empty():
file_name = queue.get()
else:
creak
if name == “main”:
main()