本篇内容主要讲解“怎么用Python一次性下载某音上的音乐”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Python一次性下载某音上的音乐”吧!

Python 链接抖音

python下载某音内容的帖子网上有一些,但都比较麻烦,需要通过adb连接安卓手机后,模拟操作。我这么懒,这种事儿玩不来…那么,该如何获取某音内容呢?网上搜了下大概有两种方式,一个是浏览器插件快抖,另外一个是我今天要说的某音网页版。其实这两者差别不是很大,都是先将某音内容下载至服务器后,通过开发简单网站配置域名后,让大家访问。

爬虫实现分析热歌榜内容

大家先开看看这个抖音热歌榜歌曲,每页20首歌曲,一个55页。但细不细心大家都能发现,很多歌曲存在重复的问题。所以,等下爬虫的时候,我们需要先准备一个music_list,用来识别这首歌曲是否已经下载过了…

网页解析

网页比较简单,一个div中包裹了一个ul>li*20,我们是不是该这样获取:

soup.find('div',{"class":"pull-left"}).find('ul').findAll('a')

如果你说是,那么一定没有好好看我前天整理的文章通过哪吒豆瓣影评,带你分析python爬虫快速入门:https://www.jianshu.com/p/ae38f7607902,我在文章中专门提到了一个小技巧,通过使用attr的属性进行快速解析,那么最快速的获取方式是:

soup.findAll('a',attrs={'onclick':True})

我们只需要获取所有的a标签,切这些标签中包含onclick这个属性即可。

巧用eval

我们解析到的内容通过attr[‘onclick'],可以得到他的属性open1(‘夜','http://p9-dy.byteimg.com/obj/61a20007a98954b0831d),如何能快速获取歌曲名字和url呢?这里我们需要用到一个eval的小技巧:

index="open1('夜','http://p9-dy.byteimg.com/obj/61a20007a98954b0831d','')"index[5:]"('夜','http://p9-dy.byteimg.com/obj/61a20007a98954b0831d','')"index_tuple=eval(index[5:])print(index_tuple,type(index_tuple))('夜','http://p9-dy.byteimg.com/obj/61a20007a98954b0831d','')<class'tuple'>index_tuple[0]'夜'index_tuple[1]'http://p9-dy.byteimg.com/obj/61a20007a98954b0831d'

ps:今天一个朋友说我写代码没注释,我这是现身说法的告诉你,如何能写出让别人压根看不懂的代码,就是不写注释啊,哈哈!其实,代码我都在文章中一点一点的讲解了,所以没有写,但秉承着害怕大佬们取关的心态,我还是把注释加上吧…

代码实现

总体来说实现比较简单,全部代码如下:

importosimportrequestsfrombs4importBeautifulSoupimportthreadingimporttimeclassDouYinMusic:def__init__(self):self.music_list=[]self.path=self.download_path()@staticmethoddefdownload_path():"""获取代码执行目录,并在目录下创建Music文件夹:returnMusic文件夹全路径"""base_dir=os.path.dirname(os.path.abspath(__file__))_path=os.path.join(base_dir,"Music")ifnotos.path.exists(_path):os.mkdir(_path)return_pathdefget_request(self,url):"""封装requests.get方法如果为网页请求,返回网页内容否则,解析音乐地址,并返回音乐二进制文件:paramurl:请求url(分网页、音乐两类):return:网页内容&音乐二进制文件"""r=requests.get(url,timeout=5)ifurl.endswith('html'):returnr.textelse:returnr.contentdefanalysis_html(self,html):"""根据获取的网页内容,解析音乐名称、下载地址调用音乐下载方法:paramhtml:网页内容"""soup=BeautifulSoup(html,'lxml')#根据关键字onclick查找每个下载地址fortag_ainsoup.findAll('a',attrs={'onclick':True}):#下载格式'("name","link","")',通过eval将str转化为tuple类型link_list=eval(tag_a['onclick'][5:])music_name,music_link=link_list[:2]#因为存在部分重复音乐,故设置判断下载过的音乐跳过ifmusic_nameinself.music_list:continueself.music_list.append(music_name)t=threading.Thread(target=self.download_music,args=(music_name,music_link))time.sleep(0.5)t.start()defdownload_music(self,music_name,music_link):"""解析音乐文件,完成音乐下载:parammusic_name:音乐名称:parammusic_link:下载地址"""_full_name=os.path.join(self.path,music_name)withopen(_full_name+'.mp3','wb')asf:f.write(self.get_request(music_link))print("抖音音乐:{}下载完成".format(music_name))defrun(self):"""主方法,用于批量生成url"""forpageinrange(1,55):url="http://douyin.bm8.com.cn/t_{}.html".format(page)html=self.get_request(url)self.analysis_html(html)if__name__=='__main__':main=DouYinMusic()main.run()

到此,相信大家对“怎么用Python一次性下载某音上的音乐”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!