接着上篇博客《用Scrapy抓取豆瓣小组数据(三)》,http://my.oschina.net/chengye/blog/124162
处理抓取的数据
我抓取了豆瓣一千多个小组的首页,获取的内容包括名称,成员数目,小组链接以及相关友情小组和推荐小组。Scrapy导出的数据格式可以是json/xml/csv等,我这边用了json格式,每个小组数据的格式如下:
02 | "groupName" : "\u5e2e\u52a9\u5927\u5c71\u91cc\u7684\u5b69\u5b50" , |
03 | "groupURL" : "http://www.douban.com/group/16533/" , |
05 | "http://www.douban.com/group/henisiben/" , |
06 | "http://www.douban.com/group/HOWPROJECT/" , |
07 | "http://www.douban.com/group/225202/" , |
08 | "http://www.douban.com/group/334177/" , |
09 | "http://www.douban.com/group/gesanghua/" , |
10 | "http://www.douban.com/group/J/" , |
11 | "http://www.douban.com/group/17551/" , |
12 | "http://www.douban.com/group/wutaishan/" , |
13 | "http://www.douban.com/group/72790/" , |
14 | "http://www.douban.com/group/ChindiaIndia/" , |
15 | "http://www.douban.com/group/74982/" , |
16 | "http://www.douban.com/group/119384/" |
由于是要进行网络分析,假设每个小组就是一个节点(vertex),如果任意两个小组是相关小组(通过RelativeGroups来判断),则两个节点相连接(edge)。所以处理脚本要做的事情,第一生成节点的列表,第二生成节点间的连接。要注意的是对抓取的的重复数据进行清理,并且保证每个连接两端的节点都是有效的。
偷懒用javascript处理了下,然后打印出一个gml格式的文件,用于下一步分析。 GML格式的非常简单,就是一个node列表加上edge列表。定义node时其实只有id是必填项,其他属性都可以自定义的。
03 | comment "Douban group graph" |
11 | url "http://www.douban.com/group/16533/" |
18 | url "http://www.douban.com/group/congming/" |
在Gephi中可视化处理网络
Gephi是一款很流行复杂网络可视化软件,我就用它打开前面生成的GML文件,然后可以对节点进行配色,分类以及布局。具体就不讲了,最后得到的网络图是这个模样的。

节点越大说明小组的连接个数越多,颜色代表着不同的小组类型(用Gephi的自带算法分类的)。下面这张图这种我划出了4个不同的区域,代表着不同类型的小组,有人能猜到分别是什么类型的小组吗?可以告诉你是哪四种:蕾丝小组,Gay小组,手工小组,美容小组。

Have Fun~