91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python 實現多線程下載視頻的代碼

發布時間:2020-08-29 01:35:27 來源:腳本之家 閱讀:334 作者:s_kangkang_A 欄目:開發技術

代碼:

def thread(url):
  r = requests.get(url, headers=None, stream=True, timeout=30)
  # print(r.status_code, r.headers)
  headers = {}
  all_thread = 1
  # 獲取視頻大小
  file_size = int(r.headers['content-length'])
  # 如果獲取到文件大小,創建一個和需要下載文件一樣大小的文件
  if file_size:
    fp = open('2.mp4', 'wb')
    fp.truncate(file_size)
    print('視頻大小:' + str(int(file_size / 1024 / 1024)) + "MB")
    fp.close()
  # 每個線程每次下載大小為5M
  size = 5242880
  # 當前文件大小需大于5M
  if file_size > size:
    # 獲取總線程數
    all_thread = int(file_size / size)
    # 設最大線程數為10,如總線程數大于10
    # 線程數為10
    if all_thread > 10:
      all_thread = 10
  part = file_size // all_thread
  threads = []
  starttime = datetime.datetime.now().replace(microsecond=0)
  for i in range(all_thread):
    # 獲取每個線程開始時的文件位置
    start = part * i
    # 獲取每個文件結束位置
    if i == all_thread - 1:
      end = file_size
    else:
      end = start + part
    if i > 0:
      start += 1
    headers = headers.copy()
    headers['Range'] = "bytes=%s-%s" % (start, end)
    t = threading.Thread(target=Handler, name='th-' + str(i),
               kwargs={'start': start, 'end': end, 'url': url, 'filename': '2.mp4', 'headers': headers})
    t.setDaemon(True)
    threads.append(t)
  # 線程開始
  for t in threads:
    time.sleep(0.2)
    t.start()
  # 等待所有線程結束
  for t in threads:
    t.join()
  endtime = datetime.datetime.now().replace(microsecond=0)
  print('用時:%s' % (endtime - starttime))
def Handler(start, end, url, filename, headers={}):
  tt_name = threading.current_thread().getName()
  print(tt_name + ' is begin')
  r = requests.get(url, headers=headers, stream=True)
  total_size = end - start
  downsize = 0
  startTime = time.time()
  with open(filename, 'r+b') as fp:
    fp.seek(start)
    var = fp.tell()
    for chunk in r.iter_content(204800):
      if chunk:
        fp.write(chunk)
        downsize += len(chunk)
        line = tt_name + '-downloading %d KB/s - %.2f MB, 共 %.2f MB'
        line = line % (
          downsize / 1024 / (time.time() - startTime), downsize / 1024 / 1024,
          total_size / 1024 / 1024)
        print(line, end='\r')
if __name__ == '__main__':
  url = input('輸入視頻鏈接(請輸入視頻原鏈):')
  thread(url)

效果:

python 實現多線程下載視頻的代碼

可以看見,38MB,一秒下完。

唯一的缺點就是,要有視頻原鏈,而一般這個視頻原鏈都是不會輕易被找到的,這就叫反爬。

找視頻原鏈,就找爬蟲,視頻爬蟲只是爬蟲的一種。

可以根據視頻大小,改變線程數。

總結

以上所述是小編給大家介紹的python 實現多線程下載視頻的代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

皮山县| 弥勒县| 临澧县| 松溪县| 福建省| 望奎县| 广东省| 古浪县| 金塔县| 延吉市| 昭通市| 东乌珠穆沁旗| 班玛县| 阜南县| 荔浦县| 个旧市| 镇宁| 蒲城县| 扎囊县| 巴中市| 子长县| 青神县| 湖南省| 松溪县| 冀州市| 且末县| 平顶山市| 启东市| 清涧县| 文登市| 行唐县| 桐梓县| 武乡县| 雷波县| 南宫市| 武隆县| 东丽区| 临武县| 绥阳县| 通海县| 承德市|