溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python 實(shí)現(xiàn)多線程下載視頻的代碼

發(fā)布時(shí)間:2020-08-29 01:35:27 來(lái)源:腳本之家 閱讀:329 作者:s_kangkang_A 欄目:開(kāi)發(fā)技術(shù)

代碼:

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'])
  # 如果獲取到文件大小,創(chuàng)建一個(gè)和需要下載文件一樣大小的文件
  if file_size:
    fp = open('2.mp4', 'wb')
    fp.truncate(file_size)
    print('視頻大?。? + str(int(file_size / 1024 / 1024)) + "MB")
    fp.close()
  # 每個(gè)線程每次下載大小為5M
  size = 5242880
  # 當(dāng)前文件大小需大于5M
  if file_size > size:
    # 獲取總線程數(shù)
    all_thread = int(file_size / size)
    # 設(shè)最大線程數(shù)為10,如總線程數(shù)大于10
    # 線程數(shù)為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):
    # 獲取每個(gè)線程開(kāi)始時(shí)的文件位置
    start = part * i
    # 獲取每個(gè)文件結(jié)束位置
    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)
  # 線程開(kāi)始
  for t in threads:
    time.sleep(0.2)
    t.start()
  # 等待所有線程結(jié)束
  for t in threads:
    t.join()
  endtime = datetime.datetime.now().replace(microsecond=0)
  print('用時(shí):%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('輸入視頻鏈接(請(qǐng)輸入視頻原鏈):')
  thread(url)

效果:

python 實(shí)現(xiàn)多線程下載視頻的代碼

可以看見(jiàn),38MB,一秒下完。

唯一的缺點(diǎn)就是,要有視頻原鏈,而一般這個(gè)視頻原鏈都是不會(huì)輕易被找到的,這就叫反爬。

找視頻原鏈,就找爬蟲(chóng),視頻爬蟲(chóng)只是爬蟲(chóng)的一種。

可以根據(jù)視頻大小,改變線程數(shù)。

總結(jié)

以上所述是小編給大家介紹的python 實(shí)現(xiàn)多線程下載視頻的代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI