基于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

相关文章

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件