想通过图形化的方式显示社交网络特定用户的好友关系,上网找了一下这方面的图形库有networkx、graphviz等,找了好久我选择了iGraph这个图形库。
igraph在Windows下的安装稍微有点麻烦,详情参见:https://my.oschina.net/stu51/blog/335455
fans.txt 和 concern.txt分别保存了粉丝昵称以及关注人昵称。
#coding=utf-8 from igraph import * count_fans=0 #粉丝数 count_following=0 #关注人数 fans_name=[] #粉丝昵称 following=[] #关注人昵称 #打开爬取下的昵称文件 with open(‘fans.txt‘,‘r‘) as f: lines=f.readlines() for line in lines: if (line!=None)&(line!=‘\n‘): fans_name.append(line) # print fans_name count_fans+=1 with open(‘concern.txt‘,‘r‘) as c: lines=c.readlines() for line in lines: if (line!=None)&(line!=‘\n‘): following.append(line) count_following+=1 g = Graph() #创建 g.add_vertices(3+count_fans+count_following) g.add_edges([(0,1),(1,2)]) g.vs[0]["name"]=‘Ta的粉丝‘ g.vs[1]["name"]=‘目标用户‘ g.vs[2]["name"]=‘Ta的关注‘ g.es["trunk"] = [True, True] g.vs["main_node"]=[1.5,3,1.5] for i in range(3,count_fans+3): g.add_edges((0,i)) g.es[i-1]["trunk"]=False for j in range(count_fans+3,3+count_fans+count_following): g.add_edges((2,j)) g.es[j-1]["trunk"]=False index=3 for fans in fans_name: g.vs[index]["name"]=fans g.vs[index]["main_node"]=False index+=1 for name in following: g.vs[index]["name"]=name g.vs[index]["main_node"]=False index+=1 visual_style = {} color_dic={1.5:"#8DB6CD",3:"#969696",False:"#97FFFF"} visual_style["vertex_label_size"]=20 visual_style["vertex_label_dist"]=2 visual_style["vertex_shape"]="circle" visual_style["vertex_size"] = [15+ 10*int(main_node) for main_node in g.vs["main_node"]] visual_style["edge_width"] = [1 + 2 * int(trunk) for trunk in g.es["trunk"]] visual_style["vertex_color"] =[color_dic[main_node] for main_node in g.vs["main_node"]] visual_style["vertex_label"] = g.vs["name"] visual_style["bbox"] = (1000, 1000) visual_style["margin"] = 100 layout = g.layout("kk") visual_style["layout"] = layout plot(g, **visual_style)
最终结果如图:
感觉看起来有点生硬╮(╯▽╰)╭
先酱,改日有空再美化下
原文:http://www.cnblogs.com/lovealways/p/6653006.html