文件多进程复制

文件多进程复制

# -*- coding :  utf-8 -*-
# @Data      :  2020-04-08
# @Author    :  Ming Xu
# @Email     :  920972751@qq.com
# @File      :  
# Desctription: 文件拷贝多进程

import os
import multiprocessing


def copy_work(source_dir, dest_dir, file_name):
    """
    根据参数拷贝文件
    :param source_dir:
    :param dest_dir:
    :param file_name:
    :return:
    """
    # 1. 拼接源文件和目标文件的具体路径
    source_path = source_dir + os.sep + file_name
    dest_path = dest_dir + os.sep + file_name
    #print("source path", source_path)
    #print("dest path", dest_path)
    print(multiprocessing.current_process())
    # 2. 打开源文件,创建目标文件
    with open(source_path, "rb") as source_file:
        # 创建目标文件
        with open(dest_path, "wb") as dest_file:
            while True:
                # 读源文件,保存到目标文件
                file_data = source_file.read(1024)
                # 判断文件是否读取完成
                if file_data:
                    dest_file.write(file_data)
                else:
                    break


    # 3. 读取源文件的内容, 写入到目标文件中



def main():
    # 1. 定义变量,保存源文件夹, 目标文件所在的路径
    source_dir = "./test"
    dest_dir = "./result"

    # 2. 在目标路径下创建文件夹
    # os.mkdir() 在指定路径下创建文件夹
    try:
        os.mkdir(dest_dir)
    except Exception as e:
        print("文件夹已经存在!")


    # 3. 获取源文件夹中所有的文件 (列表)
    file_list = os.listdir(source_dir)

    # 创建进程池
    pool = multiprocessing.Pool(3)

    # 异步方法实现

    for file_name in file_list:
        #print(file_name)

        #copy_work(source_dir, dest_dir, file_name)
        pool.apply_async(copy_work, (source_dir, dest_dir, file_name))

    pool.close() # 不能接收新的任务
    pool.join() #

    # 4. 遍历列表, 得到所有的文件名
    # 5. 定义函数, 进行文件拷贝



if __name__ == "__main__":
    main()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值