python多进程实现文件下载传输功能
作者:WangF0 发布时间:2022-06-27 02:22:41
标签:python,文件下载,文件传输
本文实例为大家分享了python多进程实现文件下载传输功能的具体代码,供大家参考,具体内容如下
需求:
实现文件夹拷贝功能(包括文件内的文件),并打印拷贝进度
模块:
os模块
multiprocessing 模块
代码:
import multiprocessing
import os
def 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("文件下载完成")
break
if __name__ == "__main__":
main()
来源:https://blog.csdn.net/wf134/article/details/78546232


猜你喜欢
- MySQL 数据表是由行和列构成的,通常把表的“列”称为字段(Field),把表的&
- 本文实例讲述了python更新列表的方法。分享给大家供大家参考。具体如下:aList = [123, 'abc', 4.56
- 看下面的一组例子:alert(true.toString());alert(false.toString());alert(1.123.to
-   MySQL行转列,对经常处理数据的同学们来说,一定是不陌生的,甚至是印象深刻,因为它大概率困扰过你,
- 语法使用 CAST:CAST ( expression AS data_type )使用 CONVERT:CONVERT (data_typ
- 在分析python的参数传递是如何进行的之前,我们需要先来了解一下,python变量和赋值的基本原理,这样有助于我们更好的理解参数传递。py
- 目前广泛使用的图像分类数据集之一是MNIST数据集。如今,MNIST数据集更像是一个健全的检查,而不是一个基准。为了提高难度,我们将在接下来
- 最简单的数组合并我们只要使用array_merge即可array_merge()将两个或多个数组的单元合并起来,一个数组中的值附加在前一个数
- 最近打算把我们的微信端用Vue.js重构,为什么选择Vue.js,一是之前使用的是传统的asp.net mvc,多页面应用用户体验比单页面要
- 1.设置phpMyAdmin Language:Chinese simplified (zh-utf-8)MySQL 字符集:UTF-8 U
- 这种问题一般是退出flask服务时选择了disconected而不是选择terminate,dicconected是一种伪断开,只是在pyc
- 导语哈喽哈喽!大家好!我是木木子,又到了每日游戏更新环节!8月30日,对暑假还意犹未尽的孩子们收到了一份“开学大礼”:通知要求,严格限制向未
- MySQLTuner 下载地址:http://github.com/rackerhacker/MySQLTuner-perlMySQLTun
- 后台服务在运行时发现一个问题,运行约15分钟后,接口请求报错pymysql.err.InterfaceError: (0, '
- Python CET自动查询方法需要用到的python方法模块有:sys、urllib2本文实例讲述了Python实现CET查分的方法。分享
- 一、python压缩模块简介python直接通过内置压缩模块可以直接进行压缩文件的创建;内置模块 zipfile/rarfile 完成压缩文
- mysql-5.6.14-win32为免安装解压缩版,安装版(http://dev.mysql.com/downloads/installe
- 前言本文主要给大家总结介绍了关于Python的一些基础技巧,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。1.starts
- 目录MySQL约束操作1.非空约束2.唯一约束3.主键约束4.外键约束5、级联MySQL约束操作概念:对表中的数据进行限定,保证数据的正确性
- 可及,通俗的说是“可以达到”,加上主语和宾语,在“交互设计”这个大的语境下,含义应该是“用户可以达到自己的操作目标”,这不是和“有效性—用户