基于Vue开发吉他谱爬虫推荐网站

2023-11-21 04:59

本文主要是介绍基于Vue开发吉他谱爬虫推荐网站,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

资源下载地址:https://download.csdn.net/download/sheziqiong/88456006
资源下载地址:https://download.csdn.net/download/sheziqiong/88456006

1 项目简介

吉他曲谱搜索推荐系统,实现 吉他曲谱展示、曲谱数据的爬虫、曲谱个性化推荐等功能的前后端分离的 Web 应用

详细设计请看 dev_doc.md

1.1 系统架构和技术选型

整体采用 B/S架构 即浏览器-服务器架构:

前端采用基于 MVVM 模型的 Vue 框架,结合 ElementUI 组件库,采用 ECharts 进行图表可视化分析,采用 Axios 库来请求或响应数据。

后端整体基于 Node.js 框架,利用 express 框架搭建服务器,提供 RESTFul 风格的接口,数据库采用 SQLite3 并有 CSV 格式文件用于保存推荐模块相关的数据,ORM 对象关系映射层为 Sequelize 框架,网络爬虫功能采用基于 JavaScript 的静态爬虫库 cheerio 以及动态爬虫库 puppeteer

1.2 系统功能

1.2.1 推荐模块

如图,用户评分信息分别计入用户评分信息文件和用户信息数据库,用户评分信息主要有三个字段:用户 ID,曲谱 ID,以及评分数据。通过曲谱信息数据库和用户评分信息就可以构建推荐算法关键的用户-曲谱评分矩阵,通过混合推荐策略为用户个性化推荐曲谱。

在系统初期,用户较少,评分信息也较少,所以通过爬取豆瓣网站相应的用户评分来构建可靠的评分数据集。随着用户增多,用户评分信息就更有价值,推荐结果就会更准确。

1.2.2 爬虫模块

各大吉他谱网站都有海量公开免费的曲谱信息,例如吉他吧网站有 609 页数据,17 吉他网站有 677 页数据……这些网站还在不断更新中。

但这些网站的曲谱信息并未作系统的分类处理,所以看上去十分纷杂。且单个曲谱的信息没有规则化,比如有的曲谱有海报,有些没有;有些曲谱有简介,有些却没有。同时,这些网站并没有曲谱的评分信息、标签分类等,但每个曲谱有对应的歌曲信息,豆瓣网站提供了歌曲的评分、分类、标签等信息,以及还有用户对歌曲的评分情况。

1.2.3 用户评分模块

用户进入曲谱详情页,会默认向后端发起 get 请求,查询该曲谱信息和用户本身的评分信息,随后在页面渲染该曲谱的详细信息以及该用户对曲谱的评分。

倘若还未进行,则评分处默认为 0。

当用户选择评分并提交评分的时候,向后端发出 put 请求来修改数据库中的评分信息,后端返回最新的用户评分信息随后重绘该详情页。

用户评分时序图如图:

1.3 数据库结构

系统以 CSV 文件格式来存储用户的评分信息,其格式为用户 id、曲谱 id、评分数据。

系统定义了曲谱和用户两个实体,其数据库表结构如下:

  1. 曲谱信息表
字段名称字段类型是否为空备注
idinteger主键、曲谱 ID、自动生成
titlevarchar(255)曲谱标题
namevarchar(255)歌曲名称
keysvarchar(255)曲谱调号
singervarchar(255)演唱歌手
postervarchar(255)曲谱海报
tagstext曲谱标签、以”; ”分割
ratingtext曲谱评分
viewsvarchar(255)曲谱浏览量
spectrumtext图片谱、以”; ”分割
descriptiontext曲谱简介
created_atdatetime曲谱创建时间
updated_atdatetime曲谱修改时间
deleted_atdatetime曲谱删除时间
  1. 用户信息表
字段名称字段类型是否为空备注
idinteger主键、用户 ID、自动生成
emailvarchar(255)用户登录和注册邮箱
passwordvarchar(255)用户密码(MD5 加密后的)
ratingstext用户评分、以”; ”分割
created_atdatetime曲谱创建时间
updated_atdatetime曲谱修改时间
deleted_atdatetime曲谱删除时间

2 项目启动

  • 项目下载到本地

    git clone https://github.com/XiDieccc/score-design.git
    
  • 进入后端开启服务器,后端地址:http://127.0.0.1/api

    cd server
    npm install
    npm run dev
    
  • 进入前端,访问前端地址:http://localhost:8080/

    cd web
    npm install
    npm run serve
    
  • 数据库初始为空,注册账户后可进行爬虫操作来获取吉他谱

资源下载地址:https://download.csdn.net/download/sheziqiong/88456006
资源下载地址:https://download.csdn.net/download/sheziqiong/88456006

这篇关于基于Vue开发吉他谱爬虫推荐网站的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/399976

相关文章

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项

一文教你如何解决Python开发总是import出错的问题

《一文教你如何解决Python开发总是import出错的问题》经常朋友碰到Python开发的过程中import包报错的问题,所以本文将和大家介绍一下可编辑安装(EditableInstall)模式,可... 目录摘要1. 可编辑安装(Editable Install)模式到底在解决什么问题?2. 原理3.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Android开发环境配置避坑指南

《Android开发环境配置避坑指南》本文主要介绍了Android开发环境配置过程中遇到的问题及解决方案,包括VPN注意事项、工具版本统一、Gerrit邮箱配置、Git拉取和提交代码、MergevsR... 目录网络环境:VPN 注意事项工具版本统一:android Studio & JDKGerrit的邮

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推