当前位置: 首页 > 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.zskr.cn/news/164276.html

相关文章:

  • Tauri 2.0 项目搭建
  • 不锈钢管路安装公司实力排行:谁能脱颖而出? - 品牌推荐大师
  • 使用JWT认证保护你的TensorFlow镜像API接口
  • 实用指南:Docker Compose高手实践之路:简单拓扑、数据库代理、基于WordPress的个人博客站点一键搞定!
  • MouseEvent
  • RocketMQ 的消息堆积问题如何解决?
  • Java 操作 Markdown(1)--commonmark-java 使用
  • KeyBoredEvent
  • 二手回收一些业务概念
  • Open-AutoGLM安卓应用场景全景图:覆盖12类移动开发任务,你的项目也能立刻落地!
  • 如何监控TensorFlow镜像中GPU利用率和温度状态
  • AI智能体架构设计:MCP、A2A、AG-UI三大协议全解析!
  • 机器翻译系统搭建:基于TensorFlow镜像训练Seq2Seq模型
  • 安全审计:系统日志审计与分析,识别潜在威胁
  • AI安全与蒙昧时代:模型监管与开源之争
  • 提示词优化效率提升300%,Open-AutoGLM实战中的10个隐藏技巧
  • 算法工程师:AI算法、LLM开发、生成式人工智能面试题(2026通关指南)
  • 手把手教你部署Open-AutoGLM,阿里云环境下性能提升8倍的秘密
  • 70款H5游戏整合小游戏平台网站源码
  • 垂直领域的大模型应用探索:深度实测3款AI聊天回复工具的差异化表现
  • 无药守护童年:小儿推拿热门品牌推荐,家长安心之选 - 速递信息
  • 【开题答辩全过程】以 基于SpringBoot的智能家具物联网平台的设计与实现为例,包含答辩的问题和答案
  • 2025-2026北京婚姻家事律师事务所权威排行:四维评测体系下的TOP5精选 - 苏木2025
  • 【毕业设计】基于springboot的深圳市体育中心体育赛事管理(源码+文档+远程调试,全bao定制等)
  • 【专家亲授】Open-AutoGLM官方镜像源推荐(国内高速下载方案)
  • 从快手直播故障,看全景式业务监控势在必行!
  • Open-AutoGLM安卓集成难题破解:3大坑点+解决方案,99%新手都中招了
  • 使用TensorFlow镜像实现联邦学习保护用户隐私
  • 【开题答辩全过程】以 基于大数据的化妆品推荐系统为例,包含答辩的问题和答案
  • 使用TensorFlow镜像训练扩散模型(Diffusion Models)可行性探讨