news 2026/4/3 3:58:38

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 - 电影推荐系统 (下)(待更新)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/28 15:51:47

Awesome Forensics:数字取证专家的终极工具箱

Awesome Forensics:数字取证专家的终极工具箱 【免费下载链接】awesome-forensics A curated list of awesome forensic analysis tools and resources 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-forensics 在当今数字化时代,数字取证…

作者头像 李华
网站建设 2026/3/30 22:05:49

Qwen3-VL-2B vs 多模态模型对比:图文理解能力与推理性能实测

Qwen3-VL-2B vs 多模态模型对比:图文理解能力与推理性能实测 1. 引言:多模态AI的演进与选型挑战 随着人工智能从单一模态向多模态融合方向发展,具备图文联合理解能力的视觉语言模型(Vision-Language Model, VLM)正成…

作者头像 李华
网站建设 2026/3/24 13:38:27

Qwen轻量级模型实战:从下载到上线的全流程解析

Qwen轻量级模型实战:从下载到上线的全流程解析 1. 引言 1.1 项目背景与技术挑战 在当前AI应用快速落地的背景下,如何在资源受限的边缘设备或CPU服务器上部署高效、稳定的语言模型服务,成为工程实践中的关键问题。传统方案通常采用“专用模…

作者头像 李华
网站建设 2026/4/2 8:20:25

数字电路实验新手教程:从认识面包板开始实践

从零开始搭建数字电路:面包板实战入门指南你有没有过这样的经历?明明按照教材画好了逻辑图,信心满满地插上芯片、接好线,结果一通电——LED不亮、计数器乱跳、芯片发热……最后只能对着一堆导线发愣。别急,这几乎是每个…

作者头像 李华
网站建设 2026/4/1 5:41:05

终极指南:5步快速上手ESP-Drone开源无人机平台

终极指南:5步快速上手ESP-Drone开源无人机平台 【免费下载链接】esp-drone Mini Drone/Quadcopter Firmware for ESP32 and ESP32-S Series SoCs. 项目地址: https://gitcode.com/GitHub_Trending/es/esp-drone ESP-Drone是一个基于ESP32系列芯片的完整开源无…

作者头像 李华
网站建设 2026/3/11 15:29:51

Qwen3-Embedding-4B功能测评:119种语言向量化真实表现

Qwen3-Embedding-4B功能测评:119种语言向量化真实表现 1. 引言:文本向量化的行业需求与技术演进 随着大模型应用的深入,语义理解能力已成为智能系统的核心基础。在检索增强生成(RAG)、跨语言搜索、文档去重、聚类分析…

作者头像 李华