文件copy器

import multiprocessing
import os, time


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(0.01)
        content = f_read.read(1024)
        if content:
            f_write.write(content)
        else:
            break
    f_read.close()
    f_write.close()

    queue.put(file_name)

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.Manager().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()

    # 显示进度
    all_file_num = len(file_names)
    while True:
        file_name = queue.get()
        if file_name in file_names:
            file_names.remove(file_name)

        copy_rate = (all_file_num - len(file_names))*100/all_file_num
        print("\r%.2f%%...(%s)" % (copy_rate, file_name) + "" *50, end="")
        if copy_rate >= 100:
            break
    print()


if __name__ == '__main__':
    main()

猜你喜欢

转载自blog.csdn.net/weixin_43192242/article/details/82683033