python社区发现_python基础教程

https://www.xin3721.com/eschool/pythonxin3721/

这是一次课程作业,实现有点粗糙。有更好的方案,欢迎交流。

我们需要评估每两个用户之间的相似度,以此来发现社区。现在我们以每对用户的共同关注人数量作为评估标准。

原始数据格式:

关注人_id:粉丝_1_id 粉丝_2_id

希望得到的输出格式是

用户_id:相似的人_1_id 相似的人_2_id

使用两次mapreduce 过程

第一次

输入格式:followee_1_id:follower_1_id follower_2_id follower_3_id

map:将后面的粉丝两两配对,并输出。key为 id-id 的形式,value为1,表示这对用户有一个共同好友

reduce: 类似wordcount,将相同key的value加起来

第二次

map:读取并切分,比如将 A-B 4 分为 a b 4 和 b a 4

reduce:将同一键的值合并到列表中, 并按相反的顺序对其进行排序。然后输出格式是 User_2:Similiar_Person_1 Similiar_Person_2 ...

此处只排出前十人。

代码:

https://github.com/londist/Community-dectection

数据集:

Small scale dataset https://www.dropbox.com/s/ntzk80l5iiiuh50/Small%20Dataset.txt?dl=0

Medium scale dataset https://www.dropbox.com/s/6sxnnadhxbyk7ho/Medium%20Dataset.txt?dl=0

Large scale dataset https://www.dropbox.com/s/lrlgz50m88j6fpc/Large%20Dataset.txt?dl=0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值