今天也是同事在做微信小程序的开发,需要音乐接口的测试,可是用网易云的开放接口比较麻烦,也不能进行测试,这里也是和我说了一下,所以就用爬虫写了个简单网易云歌曲URL的爬虫,把数据存入mysql数据库,再利用django封装装了一个简单的API接口,给同事测试使用。

创建django项目,做好基础的配置,在views里写两个方法,一个是从mysql数据库中查数据然后封装成API,一个是爬虫方法,数据扒下来以后,通过django的ORM把数据插入到mysql数据库中。
这里的路由也是对应两个,一个是爬虫的请求路由(就是运行路由),一个是接口路由,MODEL层里也是为了方便,就设了两个字段,一个是歌曲名称,一个是URL地址。

views文件代码

  1. from django.shortcuts import render,HttpResponse
  2. import requests
  3. from lxml import etree
  4. from .models import Api
  5. # Create your views here.
  6. def api_wy(request):
  7. api = Api.objects.all()
  8. return render(request, "index.html",locals())
  9. def pc(request):
  10. url = 'https://music.163.com/discover/toplist?id=3779629'
  11. headers = {
  12. 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3861.400 QQBrowser/10.7.4313.400'
  13. }
  14. data = requests.get(url=url, headers=headers)
  15. html = etree.HTML(data.text)
  16. music_list = html.xpath('//ul[@class="f-hide"]/li/a')
  17. music_lis = [] # 存放歌曲信息
  18. for music in music_list:
  19. music_name = music.xpath('./text()')[0] # 获取歌曲名称
  20. music_id_all = music.xpath('./@href')[0] # 获取a标签内容
  21. music_id = music_id_all.split('=')[-1] # 将a标签内容进行数据清洗,提取歌曲的id
  22. download_music = music_name + ' ' + f'http://music.163.com/song/media/outer/url?id={music_id}.mp3' # 将歌曲名称和url进行拼接
  23. music_lis.append(download_music)
  24. print(download_music)
  25. for url in music_lis:
  26. try:
  27. url_name = url.split(' ')[0] # 获取名称
  28. url_music = url.split(' ')[1] # 获取url
  29. Api.objects.create(name=url_name,url=url_music)
  30. print("正在插入数据")
  31. except:
  32. print("charushibai")
  33. return HttpResponse("正在下载")

URL路由文件

  1. from django.contrib import admin
  2. from django.urls import path
  3. from api.views import api_wy,pc
  4. urlpatterns = [
  5. path('admin/', admin.site.urls),
  6. path('api/',api_wy),
  7. path("pc/",pc),
  8. ]

Models层面

  1. from django.db import models
  2. # Create your models here.
  3. class Api(models.Model):
  4. name = models.CharField('歌曲名称', max_length=100)
  5. url = models.CharField("歌曲地址",max_length=300)
  6. class Meta:
  7. verbose_name = '歌曲API'
  8. verbose_name_plural = verbose_name
  9. def __str__(self):
  10. return self.name

其他的也就没什么可说的了,也是一个比较简单的测试需求,就是为了省点事情才弄得
好了,今天就到这了,拜拜

版权声明:本文为mushroom7原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/mushroom7/p/14307426.html