音悦台高清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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • [Java] volatile 详详解![通俗易懂]

    [Java] volatile 详详解![通俗易懂]前言:要真正搞懂volatile的特性需要与JMM对比来看JMM(线程安全的保证)JMM:JAVA内存模型(javamemorymodel)是一种抽象概念,并不真实存在,它描述的是一组规则或规范,通过这组规范定义了程序中各个变量(实例字段,静态字段和构成数组对象的元素)的访问方式。JMM关于同步的规定线程解锁前,必须把共享变量的值刷新回主内存;线程加锁前,必须读取主内存的最…

    2022年7月7日
    17
  • Win10 2004显示无法访问Internet小地球 却可以上网 的 简单解决办法「建议收藏」

    最简单的解决办法把下面的代码复制到记事本,并另存为为reg后缀名的文件(例如:修复网络.reg)双击打开并重启即可解决问题WindowsRegistryEditorVersion5.00[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\NlaSvc\Parameters\Internet]”ActiveDnsProbeContent”=”131.107.255.255″”ActiveDnsProbeContentV6″=”f

    2022年4月8日
    48
  • 四角号码数字在线查询_七的四角号码

    四角号码数字在线查询_七的四角号码伟大的网络,让汉字的四角号码查询变成在线的了曾经有很多人想用四角号码,但苦于太难,基本放弃了。但至从有个四角号码查询器,和四角号码输入法,使用的人又多了起来。但始终不方便,需要安装软件。而伟大的网络,

    2022年8月4日
    5
  • Linux下netstat命令详解

    Linux下netstat命令详解一、介绍Netstat是控制台命令,是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的状态信息。Netstat用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。 二、输出信息描述执行netstat后输出如下:[root@sy-suz-srv51~]#netstatActiv…

    2022年5月7日
    45
  • C# FileSystemWatcher用法详解[通俗易懂]

    C# FileSystemWatcher用法详解[通俗易懂]FileSystemWatcher控件主要功能:监控指定文件或目录的文件的创建、删除、改动、重命名等活动。可以动态地定义需要监控的文件类型及文件属性改动的类型。1.常用的几个基本属性:(1)Path:设置要监视的目录的路径。(2)IncludeSubdirectories:设置是否级联监视指定路径中的子目录。(3)Filter:设置筛选字符串,用于确定在目录中监

    2022年6月16日
    31
  • file_put_contents () failed to open stream: Permission denied 解决办法

    file_put_contents () failed to open stream: Permission denied 解决办法

    2021年11月7日
    45

发表回复

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

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