本文整理匯總了Python中core.decoder.Decoder.downloadY方法的典型用法代碼示例。如果您正苦於以下問題:Python Decoder.downloadY方法的具體用法?Python Decoder.downloadY怎麽用?Python Decoder.downloadY使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類core.decoder.Decoder
的用法示例。
在下文中一共展示了Decoder.downloadY方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: extractTargetVideo
# 需要導入模塊: from core.decoder import Decoder [as 別名]
# 或者: from core.decoder.Decoder import downloadY [as 別名]
def extractTargetVideo(link):
logger.debug("trying to decode with youtube link decrypter: " + link)
code = link[link.find("v=") + 2:]
logger.debug("trying with code: " + code)
try:
link = Decoder.downloadY(code)
except:
# trying second way, external page
html = Downloader.getContentFromUrl(link, referer=Youtube.MAIN_URL)
oldLink = link
if 'ytplayer.config = {' in html:
logger.debug("trying new way for .m3u8 links...")
link = Decoder.extract(',"hlsvp":"', '"', html).replace('\\', '')
link = urllib.unquote(link)
logger.debug("new youtube extracted link from json is: " + link)
# link += "|" + Downloader.getHeaders(oldLink)
if "http" not in link:
logger.debug("trying old second way: external resource...")
link = Youtube.decodeKeepVid(oldLink)
pass
if ".m3u8" in link:
bruteM3u8 = Youtube.getContentFromUrl(link);
if 'https://' in bruteM3u8:
m3u8 = bruteM3u8[bruteM3u8.rfind('https://'):]
link = urllib.unquote_plus(m3u8).strip()
logger.debug("using the last one inside: "+m3u8)
else:
logger.debug("no last one link selected :'(")
else:
logger.debug("nothing is transformed for youtube links.")
logger.debug("final youtube decoded url is: " + link)
if ";" in link:
link = link.replace("=", "%3D").replace(";", "%3B")
else:
link = link.replace("%3D","=")
return link