networkx
添加节点的方式
import networkx as nx
G = nx.Graph()
G.add_node(1)
G.add_nodes_from([2,3,4,100])
G.add_nodes_from([(3,{"color":"red"}),(4,{"color":"green"})])print(G)
add_node 和 add_nodes_from的区别
- add_node无论传入什么,都作为一个节点添加入图中
- add_nodes_from 传入的是一个迭代器,会将迭代器的元素分别作为一个节点,添加入图中
这个可以类比应用于
add_edge 与 add_edges_from
,
remove_node 和 remove_nodes_from
,
remove_edge 和 remove_edges_from
一种高级用法:
这样用的灵活性比较强,因为它允许图的图,文件的图,函数的图
import networkx as nx
G = nx.Graph()
H = nx.path_graph(11)# path_graph(n) => n nodes with n-1 edge
G.add_nodes_from(H)# H的结点全部添加进G中, 此时:edge = 0,node = 11
G.add_node(H)# H整个图作为一个结点添加入G中, 此时: edge = 0, node = 12
NodeView
调用
G.nodes
时,会返回NodeView,下面是使用示例
G = nx.Graph()
G.add_nodes_from([1,2],color="red")print(G.nodes.data())#[(1, {'color': 'red'}), (2, {'color': 'red'})]
G.add_node(3,size =5)# 添加节点3,属性size值为5print(G.nodes[3])# G.nodes[node_id] : 返回id为node_id 的节点属性值#{'size': 5}
添加连边的方式
添加单条连边
注:添加连边时,
G.add_edge(u_node,v_node)
这两个node可以不存在图中,会自动添加
import networkx as nx
G = nx.Graph()
G.add_nodes_from([1,2,3,4,5])
G.add_edge(1,2)#注:add_edge需要包含两个参数:起始节点的id,目的节点的id
e =(3,4)
G.add_edge(*e)#因为要包含两个参数,因此需要unpack 解压print(G)
一次性添加多条连边
G.add_edges_from([(1,5),(2,4)])print(G)
EdgeView
调用
G.edges
或者
G.edges()
时,会返回EdgeView,在访问边时,有很多用法,使用示例:
G.add_edge(1,3,color ="yellow")
G.add_edge(2,4,color ="blue")
G.edges #返回的是edgeView : [(1,3)]
G.edges.data()# 返回的是 [(1, 3, {'color': 'yellow'}), (2, 4, {'color': 'blue'})]
G.edge[1,3]# G.edges[u,v] 返回 的是(u,v) 这条边的属性: {"color":"yellow"}
G.edges.data("color")#返回的是所有边,以及边上“color”属性的属性值:[(1, 3, 'yellow'), (2, 4, 'blue')] ; 这个有参数default,可以设置default = xxx,默认为xxx。
除了单独创建点与连边之外,其他构造图的方式
为图添加属性
H = nx.Graph(day="Friday", name ="myGraph", director ="zqqcee")
使用连边创建 (自动创建节点)
G = nx.Graph()
G.add_edge(1,2)
H = nx.DiGraph(G)# 使用G的连边构造有向图Hprint(H.nodes)#[1, 2]print(H.edges)#[(1, 2), (2, 1)]
构造函数
Graph 的构造函数如下:
def__init__(self, incoming_graph_data=None,**attr)
incoming_graph_data
默认为None,可以输入nodeList,edgeList等等
# nodeList
nx.Graph([(1,2,{"key":"value"})])# edgeList
nx.Graph([(1,2),(2,3)])
访问图的节点邻居与连边
使用下标访问node
G = nx.Graph([(1,2,{"color":"yellow"})])# 传入的参数是一条边
G[1]# same as G.adj[1] ;adj = adjacency ,邻接。 G[1]表示查看节点1的邻接
G[1]
运行结果是节点1 的邻居
如果边已经存在,可以使用下标表示法获取/设置边的属性
G.add_edge(1,3)
G[1][3]['color']="blue"# 边已经存在,才能设置属性,若边(1,3)不存在则无法设置【因为G[1,3]获取的为空】
adjacency视图
G.adj
返回的是adjacency视图,示例:
G = nx.Graph()
G.add_nodes_from([1,2,3],color="red")
G.add_edge(1,3)print(G.adj)# {1: {3: {}}, 2: {}, 3: {1: {}}} , {u1:{ 与u1相邻的节点v1 :(u1,v1)边的属性 }}
清空图
G.clear()
版权归原作者 脖子好累 所有, 如有侵权,请联系我们删除。