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

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

python 下載文件的幾種方式分享

瀏覽:3日期:2022-06-23 09:39:42
1 、一般同步下載

示例代碼:

import requestsimport osdef downlaod(url, file_path): headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Firefox/68.0' } r = requests.get(url=url, headers=headers) with open(file_path, 'wb') as f: f.write(r.content) f.flush()2、 使用流式請求,requests.get方法的stream

默認情況下是stream的值為false,它會立即開始下載文件并存放到內存當中,倘若文件過大就會導致內存不足的情況,程序就會報錯。當把get函數的stream參數設置成True時,它不會立即開始下載,當你使用iter_content或iter_lines遍歷內容或訪問內容屬性時才開始下載,需要注意一點:文件沒有下載之前,它也需要保持連接。

iter_content:一塊一塊的遍歷要下載的內容iter_lines:一行一行的遍歷要下載的內容

使用上面兩個函數下載大文件可以防止占用過多的內存,因為每次只下載小部分數據。

示例代碼:

3 、異步下載文件

由于request的請求是阻塞式的,所以要用aiohttp模塊來發起請求。

示例代碼:

import aiohttpimport asyncioimport osasync def handler(url, file_path): headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Firefox/68.0' } async with aiohttp.ClientSession() as session: r = await session.get(url=url, headers=headers) with open(file_path, 'wb') as f: f.write(await r.read()) f.flush() os.fsync(f.fileno())loop = asyncio.get_event_loop()loop.run_until_complete(handler(url, file_path))4、 異步拆分下載文件

上面用的是一個協程下載一個文件,下面的方法是將文件分成幾部分,每個部分用一個協程下載,最后再寫入文件。

下面這個例子用的是流式寫入,即把內容寫入到磁盤里面。

import aiohttpimport asyncioimport timeimport osasync def consumer(queue): option = await queue.get() start = option['start'] end = option['end'] url = option['url'] filename = option['filename'] i = option['i'] print(f'第{i}個任務開始運行') async with aiohttp.ClientSession() as session: headers = {'Range': f'bytes={start}-{end}'} r = await session.get(url=url, headers=headers) with open(filename, 'rb+') as f: f.seek(start) while True:chunk = await r.content.read(end - start)if not chunk: breakf.write(chunk)f.flush()os.fsync(f.fileno())print(f'第{i}個任務正在寫入中ing') queue.task_done() print(f'第{i}個任務寫入成功')async def producer(url, headers, filename, queue, coro_num): async with aiohttp.ClientSession() as session: resp = await session.head(url=url, headers=headers) file_size = int(resp.headers['content-length']) # 創建一個文件 with open(filename, 'wb') as f: pass part = file_size // coro_num for i in range(coro_num): start = part * i if i == coro_num - 1:end = file_size else:end = start + part info = {'start': start,'end': end,'url': url,'filename': filename,'i': i, } queue.put_nowait(info)async def main(): # 需要填的有url,filename,coro_num url = '' filename = '' coro_num = 0 headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Firefox/68.0' } queue = asyncio.Queue(coro_num) await producer(url, headers, filename, queue, coro_num) task_list = [] for i in range(coro_num): task = asyncio.create_task(consumer(queue)) task_list.append(task) await queue.join() for i in task_list: i.cancel() await asyncio.gather(*task_list)startt = time.time()loop = asyncio.get_event_loop()loop.run_until_complete(main())end = time.time() - starttprint(f'用了{end}秒')5、注意

以上的示例都是介紹思路,程序并不健壯,健壯的程序需要加入錯誤捕獲和錯誤處理。

以上就是python 下載文件的幾種方式分享的詳細內容,更多關于python 下載文件的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 黄色a级毛片 | 亚洲黄色免费 | 东京不太热在线新视频 | 1024 cc香蕉在线观看看中文 | 欧美在线精品一区二区在线观看 | 国产精品嫩草影院在线 | 国产日韩一区二区 | 国产91在线|亚洲 | h网站国产 | 看免费黄色一级视频 | 国产欧美精品亚洲桃花岛 | 国产性片在线 | 亚洲一色| 伊人久久伊人 | 黄色视频毛片 | 图片专区亚洲色图 | 在线观看免费黄网站 | 国产在线精品一区二区三区 | 伊人久久大香线焦综合四虎 | 国产亚洲精品国产福利在线观看 | 久久草影视 | 拍拍拍拍拍拍拍无挡大全免费 | 三级黄色片a | 伊人久久综合网亚洲 | 泰国一级毛片aaa下面毛多 | 最新国产三级久久 | 中文字幕免费在线观看动作大片 | 女人被男人狂躁的视频免费 | 欧美精品亚洲网站 | 成人v| 影音成人资源 | 国产永久免费视频 | 成人影院欧美大片免费看 | 青草视频免费观看 | 亚洲成a人片在线观看www流畅 | 欧美日产国产亚洲综合图区一 | 麻豆视传媒短视频网站-欢迎您 | 欧美一区二区三区日韩免费播 | a国产 | 最新国产成人综合在线观看 | 青草草在线观看免费视频 |