当前位置: 首页 > news >正文

Python音乐推荐系统:Django+基于用户协同过滤(余弦相似度算法)源码

python音乐推荐系统 音乐推荐系统源码 技术栈:python+django+基于用户协同过滤,应用余弦相似度 推荐思路:用户登陆系统后,听歌时会记录听歌次数,听歌的次数可以代表用户对歌曲的喜好度,一次一分,最高10分,有了记录后再应用余弦公司计算用户相似度,得到相似度矩阵,在通过相似度矩阵*用户评分矩阵得到推荐分数矩阵,按分数高低排序推荐

打开音乐App时总能看到那些"猜你喜欢"的歌单,有些推荐准得让人怀疑手机被监听了。今天咱们自己动手撸个推荐系统,用Python+Django实现基于用户的协同过滤算法,看看这背后的魔法是怎么变出来的。

先看核心数据模型设计。在models.py里咱们得记录三样东西:用户、歌曲、用户行为。代码比文字更直观:

from django.db import models class User(models.Model): username = models.CharField(max_length=50, unique=True) class Song(models.Model): title = models.CharField(max_length=200) artist = models.CharField(max_length=100) # 音频文件路径等字段... class UserPlayHistory(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE) song = models.ForeignKey(Song, on_delete=models.CASCADE) play_count = models.IntegerField(default=0) # 用Decimal类型存评分更精确 score = models.DecimalField(max_digits=3, decimal_places=1, default=0.0) class Meta: unique_together = ('user', 'song') # 防止重复记录

用户每次播放歌曲时,咱们得更新这个评分系统。注意这里有个小技巧:播放次数转评分时做了0-10分的限制,防止数据偏差过大。看看视图层怎么处理:

def record_play(request, song_id): user = request.user song = Song.objects.get(id=song_id) history, created = UserPlayHistory.objects.get_or_create( user=user, song=song ) # 播放次数+1,但不超过10次 history.play_count = min(history.play_count + 1, 10) # 直接按播放次数作为评分 history.score = history.play_count history.save() return JsonResponse({'status': 'success'})

接下来是重头戏——相似度计算。咱们用余弦相似度来衡量用户口味有多接近。别被数学名词吓到,本质上就是比较两个用户的评分向量夹角:

from collections import defaultdict from decimal import Decimal import math def cosine_similarity(user1, user2): # 获取共同评分的歌曲 common_songs = set(user1.play_history.values_list('song', flat=True)) & \ set(user2.play_history.values_list('song', flat=True)) if not common_songs: return 0.0 # 计算点积和模长 dot_product = 0 magnitude1 = 0 magnitude2 = 0 for song in common_songs: score1 = UserPlayHistory.objects.get(user=user1, song=song).score score2 = UserPlayHistory.objects.get(user=user2, song=song).score dot_product += float(score1 * score2) magnitude1 += float(score1 ** 2) magnitude2 += float(score2 ** 2) magnitude = math.sqrt(magnitude1) * math.sqrt(magnitude2) return Decimal(dot_product / magnitude) if magnitude else 0.0

这里有个性能优化点:实际生产环境应该批量查询而不是循环内查数据库,但示例代码保持简洁优先。缓存用户评分数据能显著提升速度。

最后是推荐算法本体,这步相当于把相似用户的喜好"借"过来:

def generate_recommendations(user, top_n=10): all_users = User.objects.exclude(id=user.id) similarity_cache = {} # 缓存相似度计算结果 # 构建评分预测字典 recommendations = defaultdict(float) for other_user in all_users: # 相似度超过0.7才考虑 sim = cosine_similarity(user, other_user) if sim < 0.7: continue # 遍历相似用户听过的歌 for history in other_user.play_history.all(): if not user.play_history.filter(song=history.song).exists(): # 加权评分累加 recommendations[history.song] += float(sim * history.score) # 按评分排序取TopN sorted_songs = sorted(recommendations.items(), key=lambda x: x[1], reverse=True)[:top_n] return [song for song, _ in sorted_songs]

在前端展示推荐结果时,用Django模板引擎循环输出即可。注意要排除用户已经听过的歌曲,这个过滤逻辑在模板里可以直接处理:

<div class="recommend-box"> <h3>根据您的口味推荐</h3> <ul> {% for song in recommended_songs %} {% if song not in played_songs %} <li>{{ song.title }} - {{ song.artist }}</li> {% endif %} {% endfor %} </ul> </div>

这个系统在实际使用时会遇到冷启动问题——新用户没数据时怎么推荐?可以准备个热门歌曲榜单作为兜底方案。另一个要注意的是数据稀疏性,当用户量增大时需要考虑降维处理,或者改用矩阵分解等更高效的方法。但作为入门级的协同过滤实现,这个版本已经能展现推荐系统的核心逻辑了。

http://www.jsqmd.com/news/149473/

相关文章:

  • 【AutoGLM开源革命】:挑战OpenAI的5个关键技术突破及落地场景
  • 数据结构概述和顺序表 - f
  • Tauri 2.0 项目搭建
  • 科研新视界:书匠策AI解锁期刊论文写作的“隐形密码”
  • 实用指南:Docker Compose高手实践之路:简单拓扑、数据库代理、基于WordPress的个人博客站点一键搞定!
  • 使用MLflow跟踪TensorFlow镜像中的训练实验结果
  • 岐金兰AI元人文构想:与社科网三篇文章的对话——从工具赋能到文明共生的范式跃迁
  • 科研革命新引擎:书匠策AI解锁期刊论文写作的“智能密码”
  • MouseEvent
  • 如何监控TensorFlow镜像中GPU利用率和温度状态
  • SQL 注入防护怎么做
  • 【Open-AutoGLM技术深度解密】:揭秘下一代自动化大模型推理引擎核心架构
  • 机器翻译系统搭建:基于TensorFlow镜像训练Seq2Seq模型
  • 2025年AI已经进化到“灵魂出窍“级别,编程变“感觉“,小白程序员再不学就晚了!
  • 2025年黑龙江大理石瓷砖一线品牌排行榜,新测评精选大理石瓷砖公司推荐 - 工业设备
  • 【AI开发新范式】Anthropic颠覆认知:停止制造“Agent动物园“,通用Agent+Skills才是王炸!
  • 教育科研用途:免费获取高性能TensorFlow镜像访问权限
  • 如何通过API远程提交TensorFlow镜像训练任务
  • TensorFlow镜像中的随机种子控制:保证实验可复现性
  • 提示词优化效率提升300%,Open-AutoGLM实战中的10个隐藏技巧
  • 算法工程师:AI算法、LLM开发、生成式人工智能面试题(2026通关指南)
  • 70款H5游戏整合小游戏平台网站源码
  • 郑州西点培训服务找哪家?新测评精选西点培训公司推荐 - 工业品网
  • 手把手教你部署Open-AutoGLM,阿里云环境下性能提升8倍的秘密
  • 还在手动写对话逻辑?Open-AutoGLM自动化方案全面曝光
  • 无药守护童年:小儿推拿热门品牌推荐,家长安心之选 - 速递信息
  • 【毕业设计】基于springboot的深圳市体育中心体育赛事管理(源码+文档+远程调试,全bao定制等)
  • 【专家亲授】Open-AutoGLM官方镜像源推荐(国内高速下载方案)
  • 代码写得再好,不懂知识管理也白搭!程序员必学的AI时代知识库构建术,告别“一本正经胡说八道“!
  • 从快手直播故障,看全景式业务监控势在必行!