Python多线程下载文件实例代码
来源:互联网 发布:ubuntu标题栏透明 编辑:程序博客网 时间:2024/06/05 19:01
Python实现多线程下载文件的方法与实例代码。
实现简单的多线程下载,需要关注几点:
1.文件的大小:可以从reponse header中提取,如“Content-Length:911”表示大小是911字节
2.任务拆分:指定各个线程下载的文件的哪一块,可以通过request header中添加“Range: bytes=300-400”(表示下载300~400byte的内容),注意可以请求的文件的range是[0, size-1]字节的。
3.下载文件的聚合:各个线程将自己下载的文件块保存为临时文件,所有线程都完成后,再将这些临时文件按顺序聚合写入到最终的一个文件中。
实现代码:
实现简单的多线程下载,需要关注几点:
1.文件的大小:可以从reponse header中提取,如“Content-Length:911”表示大小是911字节
2.任务拆分:指定各个线程下载的文件的哪一块,可以通过request header中添加“Range: bytes=300-400”(表示下载300~400byte的内容),注意可以请求的文件的range是[0, size-1]字节的。
3.下载文件的聚合:各个线程将自己下载的文件块保存为临时文件,所有线程都完成后,再将这些临时文件按顺序聚合写入到最终的一个文件中。
实现代码:
#!/usr/bin/python# -*- coding: utf-8 -*-# filename: paxel.py# edit: www.jbxue.com# Jay modified it a little and save for further potential usage.'''It is a multi-thread downloading tool It was developed following axel. Author: volans E-mail: volansw [at] gmail.com'''import sysimport osimport timeimport urllibfrom threading import Thread# in case you want to use http_proxylocal_proxies = {'http': 'http://131.139.58.200:8080'}class AxelPython(Thread, urllib.FancyURLopener): '''Multi-thread downloading class. run() is a vitural method of Thread. ''' def __init__(self, threadname, url, filename, ranges=0, proxies={}): Thread.__init__(self, name=threadname) urllib.FancyURLopener.__init__(self, proxies) self.name = threadname self.url = url self.filename = filename self.ranges = ranges self.downloaded = 0 def run(self): '''vertual function in Thread''' try: self.downloaded = os.path.getsize(self.filename) except OSError: #print 'never downloaded' self.downloaded = 0 # rebuild start poind self.startpoint = self.ranges[0] + self.downloaded # This part is completed if self.startpoint >= self.ranges[1]: print 'Part %s has been downloaded over.' % self.filename return self.oneTimeSize = 16384 # 16kByte/time print 'task %s will download from %d to %d' % (self.name, self.startpoint, self.ranges[1]) self.addheader("Range", "bytes=%d-%d" % (self.startpoint, self.ranges[1])) self.urlhandle = self.open(self.url) data = self.urlhandle.read(self.oneTimeSize) while data: filehandle = open(self.filename, 'ab+') filehandle.write(data) filehandle.close() self.downloaded += len(data) #print "%s" % (self.name) #progress = u'\r...' data = self.urlhandle.read(self.oneTimeSize) def GetUrlFileSize(url, proxies={}): urlHandler = urllib.urlopen(url, proxies=proxies) headers = urlHandler.info().headers length = 0 for header in headers: if header.find('Length') != -1: length = header.split(':')[-1].strip() length = int(length) return length def SpliteBlocks(totalsize, blocknumber): blocksize = totalsize / blocknumber ranges = [] for i in range(0, blocknumber - 1): ranges.append((i * blocksize, i * blocksize + blocksize - 1)) ranges.append((blocksize * (blocknumber - 1), totalsize - 1)) return ranges def islive(tasks): for task in tasks: if task.isAlive(): return True return False def paxel(url, output, blocks=6, proxies=local_proxies): ''' paxel ''' size = GetUrlFileSize(url, proxies) ranges = SpliteBlocks(size, blocks) threadname = ["thread_%d" % i for i in range(0, blocks)] filename = ["tmpfile_%d" % i for i in range(0, blocks)] tasks = [] for i in range(0, blocks): task = AxelPython(threadname[i], url, filename[i], ranges[i]) task.setDaemon(True) task.start() tasks.append(task) time.sleep(2) while islive(tasks): downloaded = sum([task.downloaded for task in tasks]) process = downloaded / float(size) * 100 show = u'\rFilesize:%d Downloaded:%d Completed:%.2f%%' % (size, downloaded, process) sys.stdout.write(show) sys.stdout.flush() time.sleep(0.5) filehandle = open(output, 'wb+') for i in filename: f = open(i, 'rb') filehandle.write(f.read()) f.close() try: os.remove(i) pass except: pass filehandle.close()if __name__ == '__main__': url = 'http://dldir1.qq.com/qqfile/QQforMac/QQ_V3.1.1.dmg' output = 'download.file' paxel(url, output, blocks=4, proxies={})
您可能感兴趣的文章:
- python多线程实例学习
- Python多线程Socket编程的例子
- Python模块教程之thread多线程处理
- python多线程批量修改主机名
- Python多线程探测SSH主机(示例)
- python多线程下载网页的实现代码
- python多线程下载的实现代码
- python多线程Ping网段的实例代码
- python 多线程编程的例子
- python多线程异步同时执行多个函数的方法
- python多线程简明实例
0 0
- Python多线程下载文件实例代码
- python多线程代码实例
- ios--多线程下载文件代码
- Python多线程写文件实例
- Python多线程写文件实例
- 解析php多线程下载远程多个文件的实例代码
- Android实例:多线程文件下载+在线音乐播放+清除下载文件
- 多线程下载,拷贝文件java代码
- 多线程复制下载文件参考代码
- 多线程下载文件—代码优化
- Python 3中的多线程文件下载类
- Python多线程下载文件如何实现?
- java web servlet 文件下载实例代码
- Python之文件目录遍历实例代码
- loner_li windows 多线程实例 文件下载、面积计算、多线程下载等
- Java SE 多线程下载网络上的文件代码+注释
- 安卓中多线程断点续传文件下载核心代码总结
- python 多线程将大文件分开下载后在合并
- IOS工程依赖解耦之静态链接库
- swift笔记 (三) —— 字符和字符串
- iis如何下载包含中文文件名的rar文件
- 《算法设计与分析》考试说明(复习总结 与 试题提交方式、个人考勤记录——2014.05.10更新)
- Linux Shell脚本查看Java线程的CPU使用情况
- Python多线程下载文件实例代码
- C++输出wchar_t和wstring
- support vector machine -note from wiki
- coherent 和NoCoherent的正交IQ频率间隔
- u-boot学习(五):u-boot启动内核
- 代码分析工具推荐Understand
- java.util.concurrent包(4)——读写锁ReentrantReadWriteLock
- 在IOS程序中设置UIButton的字体大小
- Java Web Start为什么能加载pack.gz