python基于queue和threading实现多线程下载实例
admin
2023-07-31 02:12:20
0

本文实例讲述了python基于queue和threading实现多线程下载的方法,分享给大家供大家参考。具体方法如下:

主代码如下:

  #download worker 
  queue_download = Queue.Queue(0) 
  DOWNLOAD_WORKERS = 20 
  for i in range(DOWNLOAD_WORKERS): 
    DownloadWorker(queue_download).start() #start a download worker 
     
  for md5 in MD5S: 
    queue_download.put(md5) 
  for i in range(DOWNLOAD_WORKERS): 
    queue_download.put(None) 

其中downloadworkers.py
类继承 threading.Thread,重载run方法..在__init__中调用threading.Thread.__init__(self),
在run方法中实现耗时的操作

import threading 
import Queue 
import md5query 
import DOM 
import os,sys 

class DownloadWorker(threading.Thread): 
  \"\"\"\"\"\" 
 

  def __init__(self, queue): 
    \"\"\"Constructor\"\"\" 
    self.__queue = queue 
    threading.Thread.__init__(self) 
 
 
  def run(self): 
    while 1: 
      md5 = self.__queue.get() 
      if md5 is None: 
        break #reached end of queue 
      #this is a time-cost produce 
      self._down(md5) 
 
      print \"task:\", md5, \"finished\" 
 
  def _down(self, md5): 
    config = { 
      \'input\':sys.stdin,  
      \'output\':\'./samples\',  
      \'location\':\'xxx\',  
      \'has-fn\':False,  
      \'options\':{\'connect.timeout\':60, \'timeout\':3600},  
      \'log\':file(\'logs.txt\', \'w\'),  
    } 
    print \'download %s...\' % (md5) 
    try: 
      data = downloadproc(config[\'location\'], config[\'options\'])#我的下载过程 
      if data: 
        dom, fileData = md5query.splited(data) 
        filename = md5 
        if config[\'has-fn\']: 
          filename = \'%s_%s\' % (md5, dom.nodeValue2(\'xxxxxxx\', \'\').encode(\'utf-8\'))#这是我的下载的方法 
        f = file(os.path.join(config[\'output\'], filename), \'w\') 
        f.write(fileData) 
        f.close() 
 
        print \'%s\\tok\' % (md5) 
      else: 
        print>>config[\'log\'], \'%s\\t%s\' % (md5, \'failed\') 
    except Exception, e: 
      print>>config[\'log\'], \'%s\\t%s\' % (md5, str(e))

希望本文所述对大家的Python程序设计有所帮助。

相关内容

热门资讯

500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
Prometheus+Graf... 一,Prometheus概述 1,什么是Prometheus?Prometheus是最初在Sound...
python绘图库Matplo... 本文简单介绍了Python绘图库Matplotlib的安装,简介如下: matplotlib是pyt...