加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

发布时间:2019-10-18 20:12:35 所属栏目:教程 来源:嗨学python
导读:【大咖·来了 第7期】10月24日晚8点寓目《智能导购对话呆板人实践》 获取数据 着实逻辑并不伟大: 爬取歌单列内外的全部歌单url。 进入每篇歌单爬取全部歌曲url,去重。 进入每首歌曲首页爬取热评,汇总。 歌单列表是这样的: 翻页并调查它的url变革,留意
副问题[/!--empirenews.page--] 【大咖·来了 第7期】10月24日晚8点寓目《智能导购对话呆板人实践》

获取数据

着实逻辑并不伟大:

  • 爬取歌单列内外的全部歌单url。
  • 进入每篇歌单爬取全部歌曲url,去重。
  • 进入每首歌曲首页爬取热评,汇总。

歌单列表是这样的:

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

翻页并调查它的url变革,留意下方动图,每次翻页末端变革35。

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

回收requests+pyquery来爬取

  1. def get_list(): 
  2.  list1 = [] 
  3.  for i in range(0,1295,35): 
  4.  url = 'https://music.163.com/discover/playlist/?order=hot&cat=%E5%8D%8E%E8%AF%AD&limit=35&offset='+str(i) 
  5.  print('已乐成收罗%i页歌单n' %(i/35+1)) 
  6.  data = [] 
  7.  html = restaurant(url) 
  8.  doc = pq(html) 
  9.  for i in range(1,36): # 一页35个歌单 
  10.  a = doc('#m-pl-container > li:nth-child(' + str(i) +') > div > a').attr('href') 
  11.  a1 = 'https://music.163.com/api' + a.replace('?','/detail?') 
  12.  data.append(a1) 
  13.  list1.extend(data) 
  14.  time.sleep(5+random.random()) 
  15.  return list1 

这样我们就可以得到38页每页35篇歌单,共1300+篇歌单。

下面我们必要进入每篇歌单爬取全部歌曲url,而且要留意最后“去重”,差异歌单也许包括统一首歌曲。

点开一篇歌单,留意赤色圈出的id。

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

调查一下,我们要在每篇歌单下方获取的信息也就是红框圈出的这些,操作方才爬取到的歌单id和网易云音乐的api可以结构出:

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

不利便看的话我们理会一下json。

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手
  1. def get_playlist(url): 
  2.  data = [] 
  3.  doc = get_json(url) 
  4.  obj=json.loads(doc) 
  5.  jobs=obj['result']['tracks'] 
  6.  for job in jobs: 
  7.  dic = {} 
  8.  dic['name']=jsonpath.jsonpath(job,'$..name')[0] #歌曲名称 
  9.  dic['id']=jsonpath.jsonpath(job,'$..id')[0] #歌曲ID 
  10.  data.append(dic) 
  11.  return data  

这样我们就获取了全部歌单下的歌曲,记得去重。

  1. #去重 
  2. data = data.drop_duplicates(subset=None, keep='first', inplace=True)  

剩下就是获取每首歌曲的热评了,与前面获取歌曲相同,也是按照api结构,很轻易就找到了。

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手
  1. def get_comments(url,k): 
  2.  data = [] 
  3.  doc = get_json(url) 
  4.  obj=json.loads(doc) 
  5.  jobs=obj['hotComments'] 
  6.  for job in jobs: 
  7.  dic = {} 
  8.  dic['content']=jsonpath.jsonpath(job,'$..content')[0]  
  9.  dic['time']= stampToTime(jsonpath.jsonpath(job,'$..time')[0]) 
  10.  dic['userId']=jsonpath.jsonpath(job['user'],'$..userId')[0] #用户ID 
  11.  dic['nickname']=jsonpath.jsonpath(job['user'],'$..nickname')[0]#用户名 
  12.  dic['likedCount']=jsonpath.jsonpath(job,'$..likedCount')[0]  
  13.  dic['name']= k 
  14.  data.append(dic) 
  15.  return data  

汇总后就得到了44万条音乐热评数据。

Python爬虫44万条数据揭秘:怎样成为网易音乐评述区的网红段子手

数据说明

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读