音悦台高清mv下载_音悦台没有了去哪看mv

音悦台高清mv下载_音悦台没有了去哪看mv需要获取的页面:参考了此处,做了修改,代码如下:1#coding:utf-82importurllib23importurllib4importre5importsys6

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

需要获取的页面:

音悦台高清mv下载_音悦台没有了去哪看mv

参考了此处,做了修改,代码如下:

  1 #coding:utf-8
  2 import urllib2
  3 import urllib
  4 import re
  5 import sys
  6 import os
  7 import time
  8 
  9 
 10 class Yinyuetai():
 11 
 12     #地址初始化
 13     def __init__(self, url):
 14         self.i = 1
 15         self.url = url
 16         self.headers = {
 17             'User-Agent':'Mozilla/5.0 (Windows NT 6.3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36',
 18             'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8'
 19         }
 20         self.timeout = 30
 21         self.__init()
 22 
 23 
 24     def __init(self, page=1):
 25         print u"开始下载:第 %d 页 ..." % page
 26         reurl = self.url + "&page=%d" %page
 27         page = self.getPage(reurl)
 28         mvPageList = self.__getMvPageList(page)
 29         if len(mvPageList) > 0:
 30             for plist in mvPageList:
 31                 mvlist = self.getMvURL(plist)
 32                 self.downLoad(mvlist[0], mvlist[1].decode("utf-8"))
 33                 self.i += 1
 34             time.sleep(2)
 35             page += 1
 36             self.__init(page)
 37         else:
 38             print u"\n~~~~~~~~~~~完成!~~~~~~~~~~~~~~"
 39 
 40 
 41 
 42     #获取指定页面源码
 43     def getPage(self, url):
 44         try:
 45             request = urllib2.Request(url, None, self.headers)
 46             response = urllib2.urlopen(request, None, self.timeout)
 47             return response.read()
 48         except:
 49             return []
 50 
 51     #分析列表页,返回MV地址和名字列表[0]:视频ID[1]:视频名称
 52     def __getMvPageList(self, page):
 53             reg = r"<h3><a\shref=\"http:\/\/v.yinyuetai.com\/video\/([0-9]+)\".*title=\"(.*)\".*"
 54             pattern = re.compile(reg)
 55             findList = re.findall(pattern, page)
 56             return findList
 57             #print findList
 58 
 59 
 60 
 61     def getMvURL(self, mvlist):
 62         url = "http://www.yinyuetai.com/insite/get-video-info?flex=true&videoId=%d" % int(mvlist[0])
 63         html = self.getPage(url)
 64 
 65         reg = r"http://\w*?\.yinyuetai\.com/uploads/videos/common/.*?(?=&br)"
 66         pattern=re.compile(reg)
 67         findList = re.findall(pattern, html)
 68 
 69         if len(findList) >= 3:
 70             return [findList[2], mvlist[1]]
 71         else:
 72             return [findList[0], mvlist[1]]
 73 
 74 
 75     #end def
 76 
 77     #下载文件
 78     def downLoad(self, url, name):
 79         name = name + '.flv'
 80         print u"下载:[%s] [%d]" % (name, self.i)
 81         local = self.makeDirs() + '/' + name
 82         try:
 83             urllib.urlretrieve(url, local, self.schedule)
 84             print u"下载完成:[%s]\n" % name
 85         except:
 86             print u"下载失败!\n"
 87 
 88     def makeDirs(self):
 89         path = sys.path[0]
 90         newPath = os.path.join(path, 'flv')
 91         if not os.path.isdir(newPath):
 92             os.mkdir(newPath)
 93         return newPath
 94 
 95     """
 96     回调函数获取进度
 97     @ a 已经下载的数据块
 98     @ b 数据块的大小
 99     @ c 远程文件的大小
100     """
101     def schedule(self, a, b, c):
102         per = 100.0 *a * b / c
103         if per > 100 : per = 100
104         sys.stdout.write(u" 进度:%.1f%%\r" % per)
105         sys.stdout.flush()
106 
107 
108 
109 
110 if __name__ == '__main__':
111     url = 'http://mv.yinyuetai.com/all?pageType=page&sort=weekViews&tab=allmv&parenttab=mv'
112     Yinyuetai(url)

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168367.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MongoDB 配置

    MongoDB 配置

    2022年3月12日
    47
  • fileinput.js php,fileinput

    fileinput.js php,fileinput$(“#uploadfile”).fileinput({theme:’explorer-fa’,uploadUrl:upload_url+”?catalog=9″,language:’zh’,overwriteInitial:false,initialPreviewAsData:true,maxFileCount:3,initialPreview:pics,initialPrev…

    2022年6月7日
    29
  • 控制指定的页面刷新

    控制指定的页面刷新当我们在某个页面进行操作之后 我们希望指定的那个页面能刷新 以小程序为例子我们需要设置一个全局的变量 作为刷新的列表 存储指定刷新的页面的路由 然后定义两个全局的函数 setReflash 和 execReflash setReflash 将当前页面的上一頁的路由或者指定的多个路由添加到刷新列表中 设置返回上一页要刷新提示 callbackfunc 要回调执行的函数

    2025年7月25日
    5
  • leetcode-167两数之和(双指针+二分)

    leetcode-167两数之和(双指针+二分)原题链接给定一个已按照 升序排列 的整数数组 numbers ,请你从数组中找出两个数满足相加之和等于目标数 target 。函数应该以长度为 2 的整数数组的形式返回这两个数的下标值。numbers 的下标 从 1 开始计数 ,所以答案数组应当满足 1 <= answer[0] < answer[1] <= numbers.length 。你可以假设每个输入只对应唯一的答案,而且你不可以重复使用相同的元素。示例 1:输入:numbers = [2,7,11,15], targ

    2022年8月8日
    3
  • 我对嵌入式一些概念名词简单的理解「建议收藏」

    我对嵌入式一些概念名词简单的理解

    2022年3月7日
    58
  • lamda表达式和三个例子

    lamda表达式和三个例子(参数)->{方法语句}这样的形式就是lamda表达式,不用定义参数和返回值的数据类型-可以省略的情况:只有一个参数的时候参数可以不用括号;只有一个语句的时候大括号可以不用;只有一个语句且是return的时候可以省略return,直接写需要返回的值(表达式)目录1、for循环实例2、多线程实例3、sort排序实例1、for循环实例这个实例展示了传入一个参数且无返回值的用法定义一个字符串数组并实例化,对这个数组进行操作。通常的打印所有元..

    2022年5月10日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号