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

Day 89:【99天精通Python】项目篇(二) - 电影推荐系统 (上) - 需求分析与数据探索

Day 89:【99天精通Python】项目篇(二) - 电影推荐系统 (上) - 需求分析与数据探索

前言

欢迎来到第89天!

我们将启动本系列最后一个,也是最有趣的大型项目——电影推荐系统
推荐系统是现代互联网产品的核心(淘宝的猜你喜欢、抖音的视频流)。我们将从零开始,搭建一个能根据用户历史评分,为他推荐可能喜欢的电影的系统。

我们将使用最经典的协同过滤 (Collaborative Filtering)算法。
它的核心思想是:“物以类聚,人以群分”

  1. 找到和你品味相似的用户。
  2. 把他们喜欢但你还没看过的电影推荐给你。

本节内容:

  • 项目目标与需求分析
  • 数据集介绍 (MovieLens)
  • 数据加载与探索性分析 (EDA)
  • 算法选型:基于用户的协同过滤 (User-Based CF)

一、项目目标

开发一个 API,输入一个user_id,返回为该用户推荐的 Top 10 电影列表。


二、数据集介绍 (MovieLens)

我们将使用 GroupLens 提供的公开数据集MovieLens。它包含几百万条"用户-电影-评分"的记录。
为了方便,我们使用ml-latest-small这个子集,包含 10 万条评分。

下载并解压后,我们主要关心两个文件:

  • movies.csv:movieId,title,genres
  • ratings.csv:userId,movieId,rating,timestamp

三、数据加载与探索 (EDA)

EDA 是数据分析的第一步,先看看数据长什么样。

importpandasaspd# 1. 加载数据movies=pd.read_csv("./ml-latest-small/movies.csv")ratings=pd.read_csv("./ml-latest-small/ratings.csv")print("--- 电影数据 ---")print(movies.head())print("\n--- 评分数据 ---")print(ratings.head())# 2. 合并数据# 用 merge 把两张表连起来,方便分析df=pd.merge(ratings,movies,on="movieId")print("\n--- 合并后数据 ---")print(df.head())# 3. 基础统计n_users=df['userId'].nunique()n_movies=df['movieId'].nunique()print(f"\n用户数:{n_users}, 电影数:{n_movies}")# 4. 看看热门电影 (按评分次数排序)movie_counts=df['title'].value_counts()print("\n--- 最热门的电影 Top 5 ---")print(movie_counts.head())# 5. 看看评分分布print("\n--- 评分分布 ---")print(df['rating'].describe())

四、算法原理:基于用户的协同过滤

假设我们要为用户 A 推荐电影。

  1. 找到相似用户
    • 遍历所有其他用户 (B, C, D…)
    • 计算 A 和每个用户之间的相似度。相似度的计算基于他们共同评分过的电影。
    • 相似度算法:余弦相似度 (Cosine Similarity)是最常用的。
  2. 筛选邻居
    • 选出和 A 最相似的 Top K 个用户(比如 K=20),他们是 A 的"邻居"。
  3. 生成推荐
    • 遍历邻居们看过且评分很高,但 A没看过的电影。
    • 对这些电影进行加权评分(相似度越高的邻居,他的推荐权重越大)。
    • 按最终得分排序,返回 Top N 个电影。

五、数据准备:用户-物品评分矩阵

为了计算相似度,我们需要一个"用户-电影"的评分矩阵。

  • 行:userId
  • 列:title
  • 值:rating

这个矩阵通常是稀疏的(大部分是 NaN,因为用户只看过一小部分电影)。

# 使用 pivot_table 创建评分矩阵movie_matrix=df.pivot_table(index='userId',columns='title',values='rating')print(movie_matrix.head())# title '71 (2014) 'Hell or High Water' (2016) ...# userId# 1 NaN NaN ...# 2 NaN NaN ...

六、计算用户相似度

Scikit-Learn 提供了cosine_similarity函数。

fromsklearn.metrics.pairwiseimportcosine_similarity# 缺失值用 0 填充 (代表没看过)user_item_matrix=movie_matrix.fillna(0)# 计算用户之间的相似度user_similarity=cosine_similarity(user_item_matrix)# 包装成 DataFrame,方便查看user_sim_df=pd.DataFrame(user_similarity,index=user_item_matrix.index,columns=user_item_matrix.index)print("\n--- 用户相似度矩阵 ---")print(user_sim_df.head())# userId 1 2 3 4 5# userId# 1 1.000000 0.027283 0.059709 0.194395 0.129080# 2 0.027283 1.000000 0.000000 0.000000 0.032118

七、小结

今天是项目的第一步:理解问题和准备数据

  1. 推荐系统的核心是"相似度"。
  2. 协同过滤分为基于用户 (User-CF) 和基于物品 (Item-CF)。
  3. Pandas是数据探索和预处理的核心工具,mergepivot_table非常关键。
  4. 用户-物品评分矩阵是算法的基础。

明天 (Day 90),我们将编写核心的推荐函数,并将其封装成一个 Flask API,完成整个项目!


八、课后作业

  1. 数据可视化:使用 Matplotlib 或 Seaborn,绘制电影评分次数的直方图,看看长尾效应有多严重。
  2. Item-CF:思考一下"基于物品的协同过滤"该怎么实现?(提示:转置评分矩阵,计算电影与电影之间的相似度)。
  3. 相似用户分析:编写代码,找出与userId=1最相似的 5 个用户。

系列导航

  • 上一篇:Day 88 - 实战篇二总结
  • 下一篇:Day 90 - 电影推荐系统 (下)(待更新)
http://www.jsqmd.com/news/265961/

相关文章:

  • kkFileView国产化迁移实战:从x86到ARM架构的完整解决方案
  • AI手势识别如何实现毫秒级响应?极速CPU版实战解析
  • Keil5安装后如何验证?新手必备测试方法
  • 终极指南:open-notebook - 完全免费的AI驱动笔记管理神器
  • Hunyuan推理速度优化:batch_size设置实战教程
  • 如何快速掌握Frigate:AI智能监控的完整使用指南
  • 使用状态机设计UDS 19服务响应流程操作指南
  • 如何用Sandboxie实现安全沙箱隔离:5步完整配置指南
  • 树莓派AirPlay镜像终极指南:零配置网络发现深度解析
  • ComfyUI-WanVideoWrapper终极指南:从零搭建完整视频生成工作流
  • AI编程新体验:Open Interpreter+Qwen3-4B实测分享
  • Cap开源录屏工具终极指南:免费替代Loom的完整解决方案
  • Steam饰品交易终极助手:跨平台自动比价完整指南
  • Youtu-2B论文辅助神器:学生党1块钱体验,告别显卡焦虑
  • 从语音到情感标签的完整解析|基于SenseVoice Small镜像的实践落地
  • PicView:重新定义Windows图片浏览体验的现代解决方案
  • 电商商品识别实战:用Qwen3-VL-2B快速搭建智能客服
  • 基于UART的PLC数据采集系统:完整指南与实例分析
  • AI手势识别为何要彩虹骨骼?可视化设计实战解读
  • Qwen3-VL-2B vs 多模态模型对比:图文理解能力与推理性能实测
  • Midscene.js 快速上手指南:3分钟零基础配置视觉AI助手
  • 亲测Cute_Animal_For_Kids镜像:输入文字秒变可爱动物插画
  • GPT-SoVITS语音合成实战指南:从零开始的AI语音生成体验
  • HY-MT1.5-1.8B vs 商用API实测:云端GPU 3小时省千元测试费
  • 没显卡怎么玩ComfyUI?云端镜像2块钱搞定,小白5分钟上手
  • ImmortalWrt自动更新终极指南:7步实现智能固件管理
  • PCB电镀与蚀刻的物理机制:一文说清基本原理
  • IndexTTS2手把手教学:10分钟完成专业级配音
  • AppSmith零代码开发实战指南:轻松搭建企业级Web应用
  • 语音识别新纪元:FunASR说话人分离技术从入门到精通实战指南