特么的,上次写了一堆,发现,原来下载网易云的歌曲根本不用这么费劲,直接用!
http://music.163.com/song/media/outer/url?id=这里填歌曲id.mp3
这个URL就可以下载了,真特么操蛋!!
现在再来做一次!根据歌单下载歌曲
import requests,os,time,sys,re from scrapy.selector import Selector class wangyiyun(): def __init__(self): self.headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36', 'Referer': 'http://music.163.com/'} self.main_url='http://music.163.com/' self.session = requests.Session() self.session.headers=self.headers def get_songurls(self,playlist): '''进入所选歌单页面,得出歌单里每首歌各自的ID 形式就是“song?id=64006"''' url=self.main_url+'playlist?id=%d'% playlist re= self.session.get(url) #直接用session进入网页,懒得构造了 sel=Selector(text=re.text) #用scrapy的Selector,懒得用BS4了 songurls=sel.xpath('//ul[@class="f-hide"]/li/a/@href').extract() return songurls #所有歌曲组成的list ##['/song?id=64006', '/song?id=63959', '/song?id=25642714', '/song?id=63914', '/song?id=4878122', '/song?id=63650'] def get_songinfo(self,songurl): '''根据songid进入每首歌信息的网址,得到歌曲的信息 return:'64006','陈小春-失恋王''' url=self.main_url+songurl re=self.session.get(url) sel=Selector(text=re.text) song_id = url.split('=')[1] song_name = sel.xpath("//em[@class='f-ff2']/text()").extract_first() singer= '&'.join(sel.xpath("//p[@class='des s-fc4']/span/a/text()").extract()) songname=singer+'-'+song_name return str(song_id),songname def download_song(self, songurl, dir_path): '''根据歌曲url,下载mp3文件''' song_id, songname = self.get_songinfo(songurl) # 根据歌曲url得出ID、歌名 song_url = 'http://music.163.com/song/media/outer/url?id=%s.mp3'%song_id path = dir_path + os.sep + songname + '.mp3' # 文件路径 requests.urlretrieve(song_url, path) # 下载文件 def work(self, playlist): songurls = self.get_songurls(playlist) # 输入歌单编号,得到歌单所有歌曲的url dir_path = r'C:\Users\Administrator\Desktop' for songurl in songurls: self.download_song(songurl, dir_path) # 下载歌曲 if __name__ == '__main__': d = wangyiyun() d.work(2214059025)
搞定!代码简单得一塌糊涂,,真特么费脑子!!
以上这篇python 根据网易云歌曲的ID 直接下载歌曲的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍Python爬取网易云音乐上评论火爆的歌曲,包括了Python爬取网易云音乐上评论火爆的歌曲的使用技巧和注意事项,需要的朋友参考一下 前言 网易云音乐这款音乐APP本人比较喜欢,用户量也比较大,而网易云音乐之所以用户众多和它的歌曲评论功能密不可分,很多歌曲的评论非常有意思,其中也不乏很多感人的评论。但是,网易云音乐并没有提供热评排行榜和按评论排序的功能,没关系,本文就使用爬虫给大家爬
本文向大家介绍使用Python下载歌词并嵌入歌曲文件中的实现代码,包括了使用Python下载歌词并嵌入歌曲文件中的实现代码的使用技巧和注意事项,需要的朋友参考一下 使用python扫描本地音乐并下载歌词 这次这个真的是干货哦,昨晚弄了半晚上,,,,从8点吃完饭就开始写,一直到了快12点才弄好,,,新手,伤不起呀。。。。 先简单的说下吧,百度提供了一个音乐搜索的api,你想百度请求类似于 的地址,百
问题来源于网易云音乐增长产品实习生的面试作业题,具体的问题见1.1问题描述 一、问题背景 1.1 问题描述 背景:云音乐用户进行歌曲分享,但是分享歌曲之后通过分享歌曲打开APP的用户转化低。 问题:这个问题你怎么分析?以及对应的产品解决方案是什么? 1.2 分析框架 针对问题主要分为横向和纵向两个角度拆分: 横向按渠道划分,用户分享歌曲的渠道分为一对一和一对多两个场景 在一对一场景下,用户通过im
我试图构建一个web应用程序,它使用spotify api通过曲目id(spotify)获取歌曲/艺术家的名字,我的目的是让每个人都能使用这个web应用程序,而不仅仅是spotify用户。 有人能证实或者给我一个解决方案吗?
我正试着等一首歌唱完再弹下一首歌。 我正在windows上运行Python3.4,但正在尝试在Linux上使用它()。