python画有权重网络图_python networkx 根据图的权重画图实现

首先输入边和边的权重,随后画出节点位置,根据权重大小划分实边和虚边

2019071009445914.png

#coding:utf-8

#!/usr/bin/env python

"""

An example using Graph as a weighted network.

"""

__author__ = """Aric Hagberg (hagberg@lanl.gov)"""

try:

import matplotlib.pyplot as plt

except:

raise

import networkx as nx

G=nx.Graph()

#添加带权边

G.add_edge('a','b',weight=0.6)

G.add_edge('a','c',weight=0.2)

G.add_edge('c','d',weight=0.1)

G.add_edge('c','e',weight=0.7)

G.add_edge('c','f',weight=0.9)

G.add_edge('a','d',weight=0.3)

#按权重划分为重权值得边和轻权值的边

elarge=[(u,v) for (u,v,d) in G.edges(data=True) if d['weight'] >0.5]

esmall=[(u,v) for (u,v,d) in G.edges(data=True) if d['weight'] <=0.5]

#节点位置

pos=nx.spring_layout(G) # positions for all nodes

#首先画出节点位置

# nodes

nx.draw_networkx_nodes(G,pos,node_size=700)

#根据权重,实线为权值大的边,虚线为权值小的边

# edges

nx.draw_networkx_edges(G,pos,edgelist=elarge,

width=6)

nx.draw_networkx_edges(G,pos,edgelist=esmall,

width=6,alpha=0.5,edge_color='b',style='dashed')

# labels标签定义

nx.draw_networkx_labels(G,pos,font_size=20,font_family='sans-serif')

plt.axis('off')

plt.savefig("weighted_graph.png") # save as png

plt.show() # display

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: python networkx 根据图的权重画图实现

本文地址: http://www.cppcns.com/jiaoben/python/265070.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值