使用文本挖掘实现站点个性化推荐

简介: 一条信息是否能够让用户感兴趣,主要取决于这条信息的内容是否是用户关注的内容。而将用户……

​​本文作者韦玮原创,转载请注明出处。

技术背景

一条信息是否能够让用户感兴趣,主要取决于这条信息的内容是否是用户关注的内容。而将用户感兴趣的信息推送给对应的用户,可以更好地发挥该信息的价值,否则,不仅对应信息的价值无法有效发挥,甚至会引起用户的情绪,因为如果用户对这条信息不感兴趣,那么这条信息对于该用户来说就相当于垃圾信息。

现在关键的问题是,如何判断出现有的信息中,哪些信息是用户感兴趣的信息,从而把这些用户可能感兴趣的信息推送给用户,这样对于用户来说,可以获取期望的内容,对于企业来说,这可以更好地获取商业利益。

比如,我们在使用今日头条的时候,你会发现推送过来的文章基本上都是我们感兴趣的文章,这些文章都是个性化推荐过来的。其实,如果我们可以将这项技术更好的利用,这可以改变更多领域。

可以想象,如果小说站点采用个性化推荐技术,那么当读者在读一本小说的时候,我们可以判断该读者的兴趣,并从小说库中选择出读者可能最感兴趣的小说,并将筛选出来的小说推荐给该读者,那么此时,对于读者和网站来说是双赢的,比如就读者而言,节省了小说筛选的成本,并且可以很方便地获得自己感兴趣的内容,就网站而言,将合适的内容推荐给合适的用户,更有利于用户的付费。除此之外,个性化推荐技术还可以应用到新闻站点、商城、视频站点等等方面。

在本篇文章中,我们将为大家讲解如何采用Python文本挖掘技术实现个性化推荐技术。

文本挖掘技术(Text Mining)简介

文本挖掘技术(Text Mining)是数据挖掘技术中的一种,简单来说,文本挖掘技术就是对现有的一些文本信息进行分析、处理等,从而提取或计算出一些有价值的信息供我们使用的一种技术。

而在这篇文章中,我们主要用到文本挖掘技术中的分词、文本相似度计算等技术,而文本相似度计算我们主要会采用TF-IDF算法,相关理论知识各位读者可以自行了解,本篇文章中主要会进行实战的讲解。

将文本挖掘技术(Text Mining)应用于个性推荐的思路

那么,我们如何将文本挖掘技术应用于个性推荐呢?

看起来这两者确实不太相关,但实际上这两者关系密切。

比如,我们可以这样实现个性推荐:

1、 首先,记录用户在网站中的行为,比如看了哪些文章、阅读了哪些小说等等行为。

2、 其次,将用户长时间观看的这些小说(以小说站点为例)数据提取出来,得到数据1(data1)。

3、 然后,将data1与站点内的所有小说数据分别进行文本相似度计算,最终筛选出相似度高的小说数据,比如取前两本相似度最高的小说,得到小说2(data2)、小说3(data3)。

4、 将data2、data3推荐给该用户。因为这两本小说用户目前长时间阅读的小说相似度最高,所以一般这两本小说与用户手头上这本小说的风格、类型会基本一致,所以,一般用户同样会对这两本小说感兴趣。

5、 对于其他用户,我们同样可以采用1-4的方式给其推荐相似度高的小说。

此时我们以小说站点为例讲解了用文本挖掘技术实现个性化推荐的思路,我们可以看到,关键点在于文本相似度的计算,其他站点的实现思路也可以参照该思路进行。

核心步骤

现在我们已经明确了个性化推荐需求的实现思路,接下来我们整理一下实现的核心步骤。

我们可以采用以下步骤进行(以小说站点为例,其他站点类似):

1、读取站点中所有小说数据

2、对要计算的多本小说数据分别进行分词

3、对要计算的多本小说数据分别整理成指定格式,方便后续进行计算

4、计算出词语的频率

5、(可选)过滤掉频率低的词语

6、通过语料库建立词典

7、读取用户当前关注的小说的数据

8、将用户当前关注的小说的数据通过doc2bow转化为稀疏向量

9、对稀疏向量进行进一步处理,得到新语料库

10、将新语料库通过tfidfmodel进行处理,得到tfidf

11、通过token2id得到特征数

12、稀疏矩阵相似度计算,从而建立索引

13、分别得到用户当前关注的小说与小说库中各小说的相似度结果

14、提取出相似度高的小说,推荐给该用户

实现过程

上面我们已经讲解了实践的核心步骤,接下来我们进行具体的实现,在此采用的开发语言是Python,需要的第三方库有:jieba、gensim,需要提前使用pip安装好,如下:

pip install jieba

pip install genism

首先我们假设一下情景(为了保证前后一致,同样以小说站点为例,其他类型站点参考即可),假如现在我们的服务器中有3本小说,分别是盗墓笔记(服务器中文件名为dmbj.html)、老九门(服务器中文件名为ljm.html)、鬼吹灯(服务器中文件名为gcd.html),现在读者正在看盗墓笔记,需要我们从老九门与鬼吹灯中(加入小说库中小说更多,计算方法也是一样的)推荐一本相似度高的小说给读者。

首先,我们需要读取站点中除读者当前正在阅读的这本小说之外的所有小说数据(当然也可以把读者正在阅读的这本小说读取一下,只不过这样的话后面的结果需要去除相似度为1的小说数据),如下所示:

 import urllib.request

 #读取老九门这本小说

d1=urllib.request.urlopen("http://127.0.0.1/ljm.html").read().decode("utf-8","ignore")

#读取鬼吹灯这本小说

d2=urllib.request.urlopen("http://127.0.0.1/gcd.html").read().decode("utf-8","ignore")

读取了小说数据之后,接下来我们需要对要计算的多本小说数据分别进行分词,在这里,我们会使用jieba库进行分词处理,如下所示:

import jieba

data1=jieba.cut(d1)

data2=jieba.cut(d2)

分词之后,我们需要对要计算的多本小说数据分别整理成指定格式,方便后续进行计算,如下所示:

data11=""

for item in data1:

    data11+=item+" "

data21=""

for item in data2:

    data21+=item+" "

docs=[data11,data21]

随后,我们需要计算出各词语的频数,如下所示:

tall=[[w1 for w1 in doc.split()]

for doc in docs]

from collections import defaultdict

frequency=defaultdict(int)

for text in tall:

for token in text:

frequency[token]+=1

统计出频数之后,我们可以过滤掉频率低的词语,当然这是在词语很多的情况下,如果本来就词语量有限,比如小说的内容非常少,那么此时我们就不需要过滤了。也就是说,是否需要过滤,主要取决于词语量的大小,若词语量大,连过滤之后分析效率会更高,若词语量过小,显然不应该再过滤,否则过滤之后的词语就更少了。具体过滤的方式如下,由于这几本小说的词语量很大,所以频数在25以下的词语我们都过滤掉了:

tall=[[token for token in text if frequency[token]>25]

for text in tall]

进行了词语的过滤之后,我们需要通过语料库建立词典,具体如下所示:

dictionary=corpora.Dictionary(tall)

接下来,我们需要读取用户当前关注的小说的数据,由于刚才我们假设的情景中,用户正在读盗墓笔记这本小说,所以此时我们需要加载盗墓笔记这本小说的数据,具体如下所示:

thisnoveldata=urllib.request.urlopen("http://127.0.0.1/dmbj.html").read().decode("utf-8","ignore")

data3=jieba.cut(thisnoveldata)

data31=""

for item in data3:

    data31+=item+" "

this_novel=data31

读取了用户当前关注的小说数据之后,我们可以将用户当前关注的小说的数据通过doc2bow转化为稀疏向量,具体如下所示:

new_vec=dictionary.doc2bow(this_novel.split())

随后,我们可以对稀疏向量进行进一步处理,得到新语料库,如下所示:

corpus=[dictionary.doc2bow(text) for text in tall]

得到新语料库之后,我们可以将新语料库通过tfidfmodel进行处理,得到tfidf:

tfidf=models.TfidfModel(corpus)

然后,可以通过token2id得到特征数,如下所示:

num=len(dictionary.token2id.keys())

得到特征数之后,通过SparseMatrixSimilarity进行稀疏矩阵相似度计算,从而建立索引:

index = similarities.SparseMatrixSimilarity(tfidf[corpus], num_features=num)

接下来,我们分别得到用户当前关注的小说与小说库中各小说的相似度结果:

sim=index[tfidf[new_vec]]

此时,sim中就包含了对应的相似度计算结果,我们可以通过print(sim) 将该结果打印出来,得到的结果如下所示:

================= RESTART: D:\我的教学\Python \dmbj.py =================

Warning (from warnings module):

  File "D:\Python35\lib\site-packages\gensim\utils.py", line 840

    warnings.warn("detected Windows; aliasing chunkize to chunkize_serial")

UserWarning: detected Windows; aliasing chunkize to chunkize_serial

Warning (from warnings module):

  File "D:\Python35\lib\site-packages\gensim\utils.py", line 1015

    warnings.warn("Pattern library is not installed, lemmatization won't be available.")

UserWarning: Pattern library is not installed, lemmatization won't be available.

Building prefix dict from the default dictionary ...

Loading model from cache C:\Users\me\AppData\Local\Temp\jieba.cache

Loading model cost 0.823 seconds.

Prefix dict has been built succesfully.

[ 0.12281458  0.36768654]

可以看到,此时盗墓笔记跟老九门的相似度为0.12,鬼吹灯的相似度为0.37。

最后,我们可以提取出相似度高的小说,推荐给该用户,显然此时我们会将鬼吹灯这本小说推送给当前的读者。

写在后面的话

在这篇文章中,我们以小说站点为例对个性化推荐进行了细致的讲解,其他类型的站点也可以参照这种方法来实现个性化推荐,比如新闻网站可以计算站点所有新闻用户当前花较长时间阅读的新闻的相似度,从而进行个性化推荐。

在电商网站或视频网站中,如果要采用这种方式实现个性化推荐,由于文本资料比较缺乏,所以此时我们可以将对应视频或者对应商品的评论信息或描述信息作为文本资料进行计算,方可解决文本资料缺乏的问题。

同时,这篇文章中只是给出了个性化推荐的其中一种解决方案,实现个性化推荐还有多种多样的方案,在此,希望能够抛砖引玉,让大家对个性化推荐问题有一个较好的思考。

作者新书推荐

58d0cd32Nddf92407.jpg


目录
相关文章
|
4月前
|
机器学习/深度学习 数据采集 搜索推荐
打造个性化新闻推荐系统
【8月更文挑战第31天】在这个信息爆炸的时代,个性化新闻推荐系统成为了连接用户与海量资讯的桥梁。本文将引导你通过Python编程语言和机器学习技术,搭建一个简单的新闻推荐模型。我们将从数据预处理开始,逐步深入到模型的训练与评估,最终实现一个能够根据用户兴趣推荐新闻的系统。无论你是编程新手还是有一定基础的学习者,这篇文章都将为你打开一扇通往智能推荐世界的大门。
|
7月前
|
搜索推荐 前端开发 算法
协同过滤算法|电影推荐系统|基于用户偏好的电影推荐系统设计与开发
协同过滤算法|电影推荐系统|基于用户偏好的电影推荐系统设计与开发
116 0
|
7月前
|
搜索推荐 算法 前端开发
基于用户特征的个性化网络小说推荐系统的设计与实现
基于用户特征的个性化网络小说推荐系统的设计与实现
227 0
|
机器学习/深度学习 搜索推荐 数据挖掘
138 推荐引擎的分类
138 推荐引擎的分类
56 0
|
机器学习/深度学习 搜索推荐 算法
基于协同过滤的旅游推荐系统设计与实现(论文+源码)_kaic
摘要:旅游已经成为了大众节假日放松的主要方式,但因为不熟悉旅游地点带来的选择困难却是不可避免的。随着旅游业的发展旅游行业越来越信息化,用户获取旅游景点信息更加方便。然而,用户在选择旅游目的地时,往往会面对海量的景点信息,这导致他们难以找到适合自己的景点,同时也费时费力 。数量众多的旅游景点存在着信息过载现象且日益严重,用户在网上查找时很难真正搜索到自己感兴趣的旅游景点,对此推荐系统是一种行之有效的解决方法。目前推荐系统已在电影、新闻、音乐、电子商务等方面应用广泛,但在旅游领域还未广泛使用。各大旅游网站多是提供信息查询及订票服务,因此本文将协同过滤算法应用于旅游景点的推荐。
|
机器学习/深度学习 搜索推荐 算法
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(上)
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(上)
474 0
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(上)
|
机器学习/深度学习 Web App开发 人工智能
推荐系统专题 | 推荐系统架构与单域跨域召回模型
推荐系统专题 | 推荐系统架构与单域跨域召回模型
756 0
推荐系统专题 | 推荐系统架构与单域跨域召回模型
|
算法 搜索推荐 前端开发
基于协同过滤算法的医学新闻推荐系统
该系统基于协同过滤算法,技术采用SSM整合,mysql数据库,数据库表结构适量,具有完整的业务逻辑,系统主要分为2个角色,分别为用户和管理员,算法核心为找到与目标用户兴趣相似的用户集合,然后找到这个集合中用户喜欢的、并且目标用户没有听说过的新闻推荐给目标用户,详细功能请看演示视频。
基于协同过滤算法的医学新闻推荐系统
|
存储 搜索推荐 算法
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(下)
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(下)
589 0
基于协同过滤算法的电影推荐系统设计(二) - 推荐系统介绍(下)
|
存储 算法 搜索推荐
《推荐系统》基于标签的用户推荐系统
打开微信扫一扫,关注微信公众号【数据与算法联盟】 转载请注明出处:http://blog.csdn.net/gamer_gyt  博主微博:http://weibo.com/234654758  Github:https://github.com/thinkgamer 1:联系用户兴趣和物品的方式 2:标签系统的典型代表 3:用户如何打标签 4:基于标签的推荐系统 5:算法的改进 6:标签推荐 源代码查看地址:github查看 一:联系用户兴趣和物品的方式     推荐系统的目的是联系用户的兴趣和物品,这种联系方式需要依赖不同的媒介。
2328 0