sun*_*nny 18 python social-networking networkx python-2.7
我以.json文件的形式将我的Facebook数据导入到我的计算机上.数据格式如下:
{"nodes":[{"name":"Alan"},{"name":"Bob"}],"links":[{"source":0,"target:1"}]}
Run Code Online (Sandbox Code Playgroud)
然后,我使用这个功能:
def parse_graph(filename):
"""
Returns networkx graph object of facebook
social network in json format
"""
G = nx.Graph()
json_data=open(filename)
data = json.load(json_data)
# The nodes represent the names of the respective people
# See networkx documentation for information on add_* functions
G.add_nodes_from([n['name'] for n in data['nodes']])
G.add_edges_from([(data['nodes'][e['source']]['name'],data['nodes'][e['target']]['name']) for e in data['links']])
json_data.close()
return G
Run Code Online (Sandbox Code Playgroud)
使这个.json文件在NetworkX上使用图形.如果我找到节点的程度,我知道如何使用的唯一方法是:
degree = nx.degree(p)
Run Code Online (Sandbox Code Playgroud)
其中p是我所有朋友的图表.现在,我想绘制图形,使得节点的大小与该节点的程度相同.我该怎么做呢?
使用:
nx.draw(G,node_size=degree)
Run Code Online (Sandbox Code Playgroud)
没有工作,我想不出另一种方法.
mil*_*s82 32
nx.degree(p)返回一个dict,而node_size keywod参数需要一个标量或一个大小的数组.您可以使用dict nx.degree返回如下:
import networkx as nx
import matplotlib.pyplot as plt
g = nx.Graph()
g.add_edges_from([(1,2), (2,3), (2,4), (3,4)])
d = dict(g.degree)
nx.draw(g, nodelist=d.keys(), node_size=[v * 100 for v in d.values()])
plt.show()
Run Code Online (Sandbox Code Playgroud)

| 归档时间: |
|
| 查看次数: |
18061 次 |
| 最近记录: |