集体智慧编程:提供推荐_为评论者打分

对具体的某一用户,根据其他用户的评价结果,计算出他与每一个用户的相似程度,找出相似程度最高的前N位。
在函数中,通过similarity指定使用的相关性算法。

"""
为评论者打分
"""  
#书中算法
def topMatches(prefs,person,n = 5,similarity = sim_pearson):
    score = [(similarity(prefs,person,other),other)
                    for other in prefs if other != person]
    
    score.sort()  #从小到大
    score.reverse()   #反过来排
    return score[0:n]

#自己编写
def topMatches2(prefs,person,n = 5,similarity = sim_pearson):
    score = {}
    for item in prefs:
        if item != person:
            score[item] = similarity(prefs,person,item)
    
    score_sort = sorted(zip(score.values(),score.keys()))
    score_sort.reverse()
    score_sort = score_sort[0:n]
    return score_sort

几个小笔记:

1、列表排序,从小排到大
score.sort()
注意,这个score由元组组成 [(相似度,人名),……],它会根据元组第一个值进行排序。

2、把列表元素顺序调转
score.reverse()

3、字典如何排序:
(1)zip(score.values(),score.keys()),把字典中每个值组成(value,key)的元组,通过zip把这些元组构成列表。
(2)score_sort = sorted(zip(score.values(),score.keys())),通过sorted函数,与scort.sort()等价。

4、取列表前N个:
score[0:n]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,009评论 19 139
  • 在无锡绿点电子厂的工作,每天都是三点一线,宿舍,食堂,产线来回走动。生活虽然很平淡,但就是这样平淡的日子,才让我能...
    看一树春秋阅读 5,157评论 0 0
  • 今天在网吧下片的时候重温了一下初中时候玩的经典小游戏魔塔21层版,发现小时候还是玩的不够细。 游戏的模式是这样的:...
    李相赫的乐芙兰阅读 16,695评论 1 2
  • 大约是在2015年下半年,我开始真正接触国学。一句“日行三善,三年可改命运”打动了我。 之前的命运也不能算不好,但...
    清谈散客阅读 330评论 0 1
  • 没有鲜丽的服饰 没有帅气的外表 从不说豪言壮语 更没什么丰功伟绩 拿着微薄的工资 尽职尽责 无悔无怨 任凭岁月从指...
    也无风雨亦无晴阅读 152评论 0 0