python多进程实现文件下载传输功能
Python  /  管理员 发布于 8年前   222
本文实例为大家分享了python多进程实现文件下载传输功能的具体代码,供大家参考,具体内容如下
需求:
实现文件夹拷贝功能(包括文件内的文件),并打印拷贝进度
模块:
os模块
multiprocessing 模块
代码:
import multiprocessingimport osdef deal_file(old_dir,new_dir,file_name,queue): # 打开以存在文件 old_file = open(os.path.join(old_dir,file_name),"rb") # 创建新文件 new_file = open(os.path.join(new_dir,file_name),"wb") # 循环将内容写入新文件 while True: # 单行读取 data = old_file.readline() # 如果有内容写入否则退出 if data: new_file.write(data) else: break # 关闭文件 old_file.close() new_file.close() # 向队列中添加值用以计数,参数可填任意值 queue.put(file_name)def main(): # 创建用户输入文件的备份 old_dir = input("请输入文件名:") new_dir = "备份"+old_dir os.mkdir(new_dir) # 列出文件夹内的文件列表 file_list = os.listdir(old_dir) queue = multiprocessing.Queue(128) for file_name in file_list: pro = multiprocessing.Process(target=deal_file,args=(old_dir,new_dir,file_name,queue)) # 创建子进程 pro.start() # 定义变量用以计数 num = 0 while True: # 取出队列中的值 queue.get() # 计数器+1 num += 1 # 打印下载进度 print("\r文件已下载%.2f %%" % (num/len(file_list)*100),end="") # 如果计数等于文件长度提示完成退出 if num == len(file_list): print("文件下载完成") breakif __name__ == "__main__": main()以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
test1 在
opencode + Oh-my-openagent,我的第一个免费的ai编程智能体管家:Sisyphus中评论 test..122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..Zita 在
Google AI Studio升级全栈 vibe coding体验,可直接构建带登录和数据库的应用中评论 111222..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号
