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

溫馨提示×

溫馨提示×

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

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

python爬取m3u8連接的視頻

發布時間:2020-09-23 08:44:58 來源:腳本之家 閱讀:130 作者:lingluofengzang 欄目:開發技術

本文為大家分享了python爬取m3u8連接的視頻方法,供大家參考,具體內容如下

要求:輸入m3u8所在url,且ts視頻與其在同一路徑下

#!/usr/bin/env/python
#_*_coding:utf-8_*_
#Data:17-10-08
#Auther:蘇莫
#Link:http://blog.csdn.net/lingluofengzang
#PythonVersion:python2.7
#filename:download_movie.py

import os
import sys
import requests

reload(sys)
sys.setdefaultencoding('utf-8')

# 功能:爬取m3u8格式的視頻

# 檢查存儲路徑是否正常
def check_path(_path):
  # 判斷存儲路徑是否存在
  if os.path.isdir(_path) or os.path.isabs(_path):
    # 判斷存儲路徑是否為空
    if not os.listdir(_path):
      return _path

    else:

      print u'>>>[-] 目標文件不為空,將清空目標文件,是否更換路徑?'
      flag = raw_input('>>>[*] Yes:1 No:2 \n>>>[+] [2]')

      try:
        if flag == '1':
          _path = raw_input(unicode('>>>[+] 請輸入目標文件路徑。\n>>>[+] ').encode('gbk'))
          check_path(_path)
        else:
          # 清空存儲路徑
          os.system('rd /S /Q ' + _path)
          os.system('mkdir ' + _path)
          return _path
      except Exception as e:
        print e
        exit(0)

  else:
    os.makedirs(_path)
    return _path

# 獲取ts視頻的爬取位置
def get_url(_url, _path):

  all_url = _url.split('/')
  url_pre = '/'.join(all_url[:-1]) + '/'
  url_next = all_url[-1]

  os.chdir(_path)
  # 獲取m3u8文件
  m3u8_txt = requests.get(_url, headers = {'Connection':'close'})
  with open(url_next, 'wb') as m3u8_content:
    m3u8_content.write(m3u8_txt.content)
  # 提取ts視頻的url
  movies_url = []
  _urls = open(url_next, 'rb')
  for line in _urls.readlines():
    if '.ts' in line:
      movies_url.append(url_pre + line[:-1])
    else:
      continue

  _urls.close()
  return movies_url

# 爬取ts視頻
def download_movie(movie_url, _path):
  os.chdir(_path)
  print '>>>[+] downloading...'
  print '-' * 60
  error_get = []

  for _url in movie_url:
    # ts視頻的名稱
    movie_name = _url.split('/')[-1][-6:]

    try:
      # 'Connection':'close' 防止請求端口占用
      # timeout=30  防止請求時間超長連接
      movie = requests.get(_url, headers = {'Connection':'close'}, timeout=60)
      with open(movie_name, 'wb') as movie_content:
        movie_content.writelines(movie)
      print '>>>[+] File ' + movie_name + ' done'
    # 捕獲異常,記錄失敗請求
    except:
      error_get.append(_url)
      continue
  # 如果沒有不成功的請求就結束
  if error_get:
    print u'共有%d個請求失敗' % len(file_list)
    print '-' * 60
    download_movie(error_get, _path)
  else:
    print '>>>[+] Download successfully!!!'

if __name__ == '__main__':
  try:

    _url = raw_input(unicode('>>>[+] 請輸入指定的[.m3u8]目標URL。\n>>>[+] ').encode('gbk'))
    _path = raw_input(unicode('>>>[+] 請輸入存儲目標文件路徑。\n>>>[+] ').encode('gbk'))

    storage_path = check_path(_path)
    movie_url = get_url(_url, storage_path)
    download_movie(movie_url, storage_path)

  except Exception as e:
    print e

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

汕头市| 海盐县| 井冈山市| 松滋市| 库车县| 宣武区| 容城县| 民乐县| 沾益县| 新余市| 荃湾区| 偃师市| 滦平县| 筠连县| 新源县| 东源县| 桃园县| 乳山市| 玉树县| 达尔| 沅江市| 鹤庆县| 曲麻莱县| 浮山县| 山阴县| 阳城县| 河东区| 渭源县| 商南县| 普定县| 亳州市| 灵寿县| 九江县| 乌苏市| 梅河口市| 吴桥县| 景宁| 崇明县| 红原县| 二连浩特市| 乌拉特后旗|