python+协同过滤算法实现简单的图书推荐系统

背景介绍

当我们做一些推荐系统网站时,通常需要合适的推荐算法,下面给大家介绍推荐系统中经典的推荐算法——协同过滤算法。在本文中通过Python语言,以一个图书推荐系统为案例,最终实现一个基于用户对图书的评分而对指定的用户个性化推荐的网站系统。(ps:本文中介绍的是算法的简单示例,如需项目功能扩展,可在最下方联系我

协同过滤算法

协同过滤是一种常用于推荐系统中的算法,用于预测用户可能感兴趣的物品或内容。它的核心思想是基于用户行为和相似性来进行预测,而不依赖于物品或用户的内容特征。协同过滤算法根据用户和物品之间的交互历史,发现用户之间的相似性或物品之间的相似性,从而为用户生成个性化的推荐列表。
协同过滤算法可以分为两种主要类型:基于用户的协同过滤和基于物品的协同过滤。

  1. 基于用户的协同过滤: 这种方法首先计算用户之间的相似性,然后利用与目标用户相似的其他用户的偏好来预测目标用户对物品的评分或喜好。基于用户的协同过滤通常包括以下步骤:
    • 相似性计算: 使用一些相似性度量(如余弦相似度、皮尔逊相关系数等)来计算用户之间的相似性。
    • 邻居选择: 选取与目标用户最相似的一些用户作为邻居。
    • 预测生成: 利用邻居用户对物品的评分来预测目标用户对尚未互动过的物品的评分。
  2. 基于物品的协同过滤: 这种方法通过计算物品之间的相似性来预测用户对尚未互动过的物品的评分或喜好。基于物品的协同过滤一般包括以下步骤:
    • 相似性计算: 计算物品之间的相似性,通常与用户的历史行为相关。
    • 邻居选择: 选取与目标物品最相似的一些物品作为邻居。
    • 预测生成: 基于目标用户对邻近物品的评分,预测用户对尚未互动过的物品的评分。

协同过滤算法的优点在于它能够捕捉用户和物品之间的复杂关系,从而提供个性化的推荐。然而,它也面临一些挑战,比如“冷启动”问题(新用户或新物品如何进行推荐)、数据稀疏性(用户和物品之间的交互数据可能非常少)、推荐偏差(可能会忽视一些长尾物品)等。

代码示例

在本文中通过使用Django框架作为网站开发的后端框架。其数据表模型结构如下:
image-20230827204556229

  • db_user_info:用户信息表
  • db_book:书籍表
  • db_rating:书籍评分表

在本文中通过使用基于用户的协同过滤算法,在计算相似度时选用余弦相似度计算公式。余弦相似度衡量两个向量之间的方向一致程度。在这里,向量是用户对共同评价过的图书的评分。余弦相似度计算公式为:
c o s i n e s i m i l a r i t y = ∑ i u s e r 1 _ s c o r e s [ i ] × u s e r 2 _ s c o r e s [ i ] ∑ i u s e r 1 _ s c o r e s [ i ] 2 × ∑ i u s e r 2 _ s c o r e s [ i ] 2 cosine_similarity = \frac{\sum_{i} user1\_scores[i] \times user2\_scores[i]}{\sqrt{\sum_{i} user1\_scores[i]^2} \times \sqrt{\sum_{i} user2\_scores[i]^2}} cosinesimilarity=iuser1_scores[i]2 ×iuser2_scores[i]2 iuser1_scores[i]×user2_scores[i]
代码如下:

def calculate_cosine_similarity(user_ratings1, user_ratings2):# 将用户1的图书评分存入字典,键为图书ID,值为评分book_ratings1 = {rating.book_id: rating.score for rating in user_ratings1}# 将用户2的图书评分存入字典,键为图书ID,值为评分book_ratings2 = {rating.book_id: rating.score for rating in user_ratings2}# 找出两个用户共同评价过的图书common_books = set(book_ratings1.keys()) & set(book_ratings2.keys())if len(common_books) == 0:return 0.0  # 无共同评价的图书,相似度为0# 提取共同评价图书的评分,存入NumPy数组user1_scores = np.array([book_ratings1[book_id] for book_id in common_books])user2_scores = np.array([book_ratings2[book_id] for book_id in common_books])# 计算余弦相似度cosine_similarity = np.dot(user1_scores, user2_scores) / (np.linalg.norm(user1_scores) * np.linalg.norm(user2_scores))return cosine_similarity

其中,user1_scores 和 user2_scores 是两个用户的评分向量,i 是共同评价过的图书的索引。实现步骤如下:

首先遍历所用其他的用户,对于每个其他用户计算与目标用户的余弦相似度。如果相似度大于0,那么遍历其他用户评价的图书,创建推荐记录包括加权评分和相似度。然后按照分数大小降序排列。将对应的图书名称信息等返回给用户。

实验效果

在这里插入图片描述
Python网站开发、项目订制、请扫下方名片

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/1620470.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

如何使用腾讯云服务器搭建网站?新手建站教程

使用腾讯云服务器搭建网站全流程,包括轻量应用服务器和云服务器CVM建站教程,轻量可以使用应用镜像一键建站,云服务器CVM可以通过安装宝塔面板的方式来搭建网站,腾讯云服务器网分享使用腾讯云服务器建站教程,新手站长搭…

代码随想录算法训练营第四十八天|LeetCode 583,72,编辑距离总结篇

目录 LeetCode 583.两个字符串的删除操作 动态规划五步曲: 1.确定dp[i][j]的含义 2.找出递推公式 3.初始化dp数组 4.确定遍历方向 5.打印dp数组 LeetCode 72.编辑距离 动态规划五步曲: 1.确定dp[i][j]的含义 2.找出递推公式 3.初始化dp数组 4.确定遍历方…

JAVA rs232

JAVA rs232 全套资源提供 全套项目资源环境都在我发布的资源里环境 MAVEN 依赖代码贴出 全套项目资源环境都在我发布的资源里 环境 Configure Virtual Serial Port Driver 模拟串口 友善串口工具调试 MAVEN 依赖 <dependency><groupId>org.bidib.jbidib.org.qba…

java输出hello world_java输出Hello World

一、输出“Hello World!” 1、新建一个java项目,点击File->New->Java Project,创建java项目的界面之后,输入项目名称wly,点击finish。 2、创建好java项目之后,鼠标右键项目,选择New->Class,创建一个类,mypackage为包名,Name类名Hello,首字母大写,点击fini…

二,java输出hello

1&#xff0c;创建文件Hello.java 2, 文件里输入 public class Hello{public static void main(String[] args){System.out.print("hello world!");} } 3&#xff0c; javac Hello.java 会生成一个class文件 4&#xff0c; 然后java Hello 注意&#xff1a; 1…

Go语言入门记录:从基础到变量、函数、控制语句、包引用、interface、panic、go协程、Channel、sync下的waitGroup和Once等

程序入口文件的包名必须是main&#xff0c;但主程序文件所在文件夹名称不必须是main&#xff0c;即我们下图hello_world.go在main中&#xff0c;所以感觉package main写顺理成章&#xff0c;但是如果我们把main目录名称改成随便的名字如filename也是可以运行的&#xff0c;所以…

C语言练习5(巩固提升)

C语言练习5 选择题 选择题 1&#xff0c;下面代码的结果是&#xff1a;( ) #include <stdio.h> #include <string.h> int main() {char arr[] { b, i, t };printf("%d\n", strlen(arr));return 0; }A.3 B.4 C.随机值 D.5 &#x1f4af;答案解析&#…

阿里云servless实现身份证智能识别Demo

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 前言 servless实现身份证智能识别。 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、如何快速实现阿里云Servless实现身份识别&#xff1f; 1…

观察级水下机器人使用系列之六超短基线(下)

本文主要讲述超短基线的安装校准和应用。 1、安装校准概述 水下声学导航系统标定算法的准确性很大程度上取决于所采集的数据质量、超短基线基阵的几何结构、高效的数值计算算法等方面。Mc Ewen 等在 2005 年发现了对于分立式的超短基线系统&#xff0c;水声传感器与姿态传感器…

附加题——有趣的搜索《我最怕的就是计算机系的学生被别人说成是个带着厚眼镜的,只能够在电脑前编编程序》...

链接&#xff1a;链接 学校/专业&#xff1a; 无 作者&#xff1a;钻石之黎明 时间&#xff1a;2008-10-04 19:22:40 链接&#xff1a;链接 学校/专业&#xff1a; 无 转载者&#xff1a;foresee 时间&#xff1a;2008-12-10 11:43:17 链接&#xff1a;链接 学校/专业&#xff…

外包,我也挺知足

今天给大家介绍一位录友&#xff0c;这位录友很特别&#xff0c;看完他的故事&#xff0c;你会感觉自己的起步已经很高了。 他15年上大学用不起智能机。读计算机专业&#xff0c;却买不起电脑。家里去年才通网。找工作的时候不知道要多少工资&#xff0c;让HR看着给就行。入职…

C#---第十九课:不同类型方法的执行顺序(new / virtual / common / override)

本文介绍不同类型的方法&#xff0c;在代码中的执行顺序问题&#xff1a; 构造方法普通方法&#xff08;暂用common代替&#xff09;、虚方法&#xff08;Virtual修饰&#xff09;、New方法&#xff08;new修饰&#xff09;三个优先级相同overide方法&#xff08;会替换virtual…

[Android]JNI的基础知识

目录 1.什么是JNI 2.配置JNI开发环境NDK 3.创建Native C类型的项目 4. 了解CMakeLists.txt 文件 5.了解native-lib.cpp 文件 6.在 Android 的 MainActivity 中调用 native-lib.cpp 中实现的本地方法 1.什么是JNI JNI&#xff08;Java Native Interface&#xff09;是一…

vue项目打包后出现页面布局异常、图片显示不出来等问题

通常我们写完vue项目后&#xff0c;会执行 npm run serve 对项目进行打包。执行完后&#xff0c;就在项目的目录中生成dist文件夹。一开始&#xff0c;我以为双击dist文件夹里index.html会把打包后的项目运行起来&#xff0c;结果在浏览器看到的页面布局异常以及许多图片没有加…

word无法显示图像计算机可能没有足够的,Word图片显示不出来怎么办 Word图片显空白的解决办法-电脑教程...

最近百事网小编钢琴下的旋律发来了一些Word投稿文档&#xff0c;不过奇怪的是Word里边的很多图片都显示不出来&#xff0c;原先以为可能是图片过多&#xff0c;可能一下子没载入完&#xff0c;不过等待很长一段时间后&#xff0c;很多Word里边的图片依旧显示不出现&#xff0c;…

java 选择图片 显示不出来的_java图片显示不出来怎么办

java图片显示不出来怎么办&#xff1f; 解决javaweb项目使用Tomcat服务在网页中的某些页面中的图片无法显示问题。 最近写了一个web项目&#xff0c;但在浏览器中测试&#xff0c;发现某些页面中的图片无法显示。 推荐教程&#xff1a;《java学习》 原因是在加载页面时一些img标…

html显示网上图片不显示不出来,网页图片显示不出来,教您网页不显示图片怎么办...

在使用电脑浏览网页的时候是不是有碰到过网页不显示图片的时候&#xff1f;可能因为是网速慢&#xff0c;所以造成加载图片失败;当然也有其他的原因&#xff0c;像有些地方设置错误的话也会导致网页图片显示不出来的。下面&#xff0c;小编跟大伙一同探讨一下网页不显示图片的解…

java界面怎么加图片不显示不出来_java图片显示不出来怎么办,

详细内容 java图片显示不出来怎么办&#xff1f; 解决javaweb项目使用Tomcat服务在网页中的某些页面中的图片无法显示问题。 最近写了一个web项目&#xff0c;但在浏览器中测试&#xff0c;发现某些页面中的图片无法显示。 推荐教程&#xff1a;《java学习》 原因是在加载页面时…

html背景图片为什么找不到,css中背景图片显示不出来

css中背景图片显示不出来 css添加背景图片无法显示&#xff0c;有以下几方面原因&#xff1a; 1、css没有被调用&#xff1b;请检查css调用是否成功。 2、css图片地址不对&#xff1b;请检查css图片地址是否正确。 3、div的高度没有固定&#xff0c;是auto或者没有设值&#xf…