亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python實現多線程下載腳本的示例代碼

瀏覽:85日期:2022-07-31 09:04:40

0x01 分析

一個簡單的多線程下載資源的Python腳本,主要實現部分包含兩個類:

Download類:包含download()和get_complete_rate()兩種方法。

download()方法種首先用 urlopen() 方法打開遠程資源并通過 Content-Length獲取資源的大小,然后計算每個線程應該下載網絡資源的大小及對應部分嗎,最后依次創建并啟動多個線程來下載網絡資源的指定部分。 get_complete_rate()則是用來返回已下載的部分占全部資源大小的比例,用來回顯進度。

ThreadDownload類:該線程類繼承了threading.Thread類,包含了一個run()方法。

run()方法主要負責每個線程讀取網絡數據并寫入本地。

0x02 代碼

# 文件名:ThreadDownload.pyimport threadingfrom urllib.request import *class Download: def __init__(self, link, file_path, thread_num): # 下載路徑 self.link = link # 保存位置 self.file_path = file_path # 使用多少線程 self.thread_num = thread_num # 初始化threads數組 self.threads = [] def download(self): req = Request(url=self.link, method=’GET’) req.add_header(’Accept’, ’*/*’) req.add_header(’Charset’, ’UTF-8’) req.add_header(’Connection’, ’Keep-Alive’) f = urlopen(req) # 獲取要下載的文件的大小 self.file_size = int(dict(f.headers).get(’Content-Length’, 0)) f.close() # 計算每個線程要下載的資源的大小 current_part_size = self.file_size // self.thread_num + 1 for i in range(self.thread_num): # 計算每個線程下載的開始位置 start_pos = i * current_part_size # 每個線程使用一個wb模式打開的文件進行下載 t = open(self.file_path, ’wb’) t.seek(start_pos, 0) # 創建下載線程 td = ThreadDownload(self.link, start_pos, current_part_size, t) self.threads.append(td) td.start() # 獲下載的完成百分比 def get_complete_rate(self): sum_size = 0 for i in range(self.thread_num): sum_size += self.threads[i].length return sum_size / self.file_sizeclass ThreadDownload(threading.Thread): def __init__(self, link, start_pos, current_part_size, current_part): super().__init__() # 下載路徑 self.link = link # 當前線程的下載位置 self.start_pos = start_pos # 定義當前線程負責下載的文件大小 self.current_part_size = current_part_size # 當前文件需要下載的文件快 self.current_part = current_part # 定義該線程已經下載的字節數 self.length = 0 def run(self): req = Request(url = self.link, method=’GET’) req.add_header(’Accept’, ’*/*’) req.add_header(’Charset’, ’UTF-8’) req.add_header(’Connection’, ’Keep-Alive’) f = urlopen(req) # 跳過self.start_pos個字節,表明該線程只負責下載自己負責的那部分內容 for i in range(self.start_pos): f.read(1) # 讀取網絡數據,并寫入本地 while self.length < self.current_part_size: data = f.read(1024) if data is None or len(data) <= 0:break self.current_part.write(data) # 累計該線程下載的總大小 self.length += len(data) self.current_part.close() f.close()

#!/usr/bin/env python # -*- coding: utf-8 -*- # 文件名:thread_download-master.pyimport sysimport timefrom ThreadDownload import *def show_process(dl): while dl.get_complete_rate() < 1: complete_rate = int(dl.get_complete_rate()*100) print(’r’ + ’下載中···(已下載’ + str(complete_rate) + ’%)’, end=’’, flush=True) time.sleep(0.01)def main(): try: Link = input(’[+]’ + ’Link: ’) file_path = input(’[+]’ + ’File Path: ’) thread_number = input(’[+]’ + ’Thread Number: ’) thread_number = int(thread_number) dl = Download(Link, file_path, thread_number) dl.download() print(’n開始下載!’) show_process(dl) print(’r’ + ’下載中···(已下載’ + ’100%)’, end=’’, flush=True) print(’n下載完成!’) except Exception: print(’Parameter Setting Error’) sys.exit(1)if __name__==’__main__’: main()

0x03 運行結果

下載歌曲《男孩》為例,下載到./Download/目錄下并命名為男孩.mp3,設置5個線程:

Python實現多線程下載腳本的示例代碼

Python實現多線程下載腳本的示例代碼

下載成功:

Python實現多線程下載腳本的示例代碼

到此這篇關于Python實現多線程下載腳本的示例代碼的文章就介紹到這了,更多相關Python 多線程下載腳本內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产妇女性爽视频免费 | 日韩精品一 | 亚洲精品一区二区三区四 | 一级黄色免费 | 水蜜桃爱爱yy视频在线观看 | 午夜影视污 | 乱爱性全过程免费视频 | 91社区在线观看 | 三上悠亚先锋影音xfplay | 亚洲高清视频免费 | 97青青青国产在线播放 | 91福利一区二区三区 | 国产第一页无线好源 | 人做人爱视频欧美在线观看 | 一级毛片短视频 | 青青在线精品2018国产 | 91日韩视频在线观看 | 国产精品欧美亚洲韩国日本 | 国产精品99在线观看 | 国产一级毛片视频在线! | 在线观看www日本免费网站 | 妞干网在线免费观看 | 国产精品免费观看网站 | 免费黄网大全 | 亚洲欧美综合 | 久久人人青草97香蕉 | 日韩做爰视频免费 | 黑人爱爱视频 | 久久精品视频免费看 | 久久本道久久综合伊人 | 一 级 黄 色 大片 | 国产99久久精品一区二区 | 黄色一级片黄色一级片 | 国产sss| 日本a在线免费观看 | 久久99精品久久久久久欧洲站 | 91色在线观看国产 | 色综合色狠狠天天久久婷婷基地 | 国产初高中生厕所小便 | 久热中文字幕精品视频在线 | 青青热久免费精品视频精品 |