python画有权重网络图_使用Python的networkx绘制精美网络图教程
最近因为数学建模3天速成Python,然后做了一道网络的题,要画网络图。在网上找了一些,发现都是一些很基础的丑陋红点图,并且关于网络的一些算法也没有讲,于是自己进http://networkx.github.io/学习了一下。以下仅博主自己的总结,勿认真,有错误尽情指出,大家一起交流。
需要用到的module malplotlib.pyplot 和networkx
正文:
一、malplotlib和networkx的安装(作者使用的是python2.7 pycharm)
在Python的文件夹目录下Scripts目录中,如果有pip.exe 文件,那么可以用cmd 进入这个目录,然后输入 `pip insall --pre matplotlib`直接下载。如果有easy_install 也可以输入`easy_install。如果都不行就去官网 https://pypi.python.org/pypi/matplotlib/1.5.3`找对应版本下载。
至于networkx,pycharm的porject interpreter里添加就好。
二、创建图
networkx有四种图 Graph 、DiGraph、MultiGraph、MultiDiGraph,分别为无多重边无向图、无多重边有向图、有多重边无向图、有多重边有向图。
import network as nx
G = nx.Graph()#创建空的网络图
G = nx.DiGraph()
G = nx.MultiGraph()
G = nx.MultiDiGraph()
然后是加点和边了,有多种方法
G.add_node('a')#添加点a
G.add_node(1,1)#用坐标来添加点
G.add_edge('x','y')#添加边,起点为x,终点为y
G.add_weight_edges_from([('x','y',1.0)])#第三个输入量为权值
#也可以
list = [[('a','b',5.0),('b','c',3.0),('a','c',1.0)]
G.add_weight_edges_from([(list)])
然后是图形的显示
#需要导入matplotlib
import matplotlib.pyplot as plt
nx.draw(G)
plt.show()
为了让图形更精美我们详解nx.draw()
nx.draw(G,pos = nx.random_layout(G),node_color = 'b',edge_color = 'r',with_labels = True,font_size =18,node_size =20)
pos 指的是布局 主要有spring_layout , random_layout,circle_layout,shell_layout。node_color指节点颜色,有rbykw ,同理edge_color.
with_labels指节点是否显示名字,size表示大小,font_color表示字的颜色。
看到这里,各位应该就能画出大量网站上的基本networkx简单教程了,大概是这个样子
三、绘制精美的图
如果你想要的图是这样的
或是这样的
还是这样的
可以继续看下去
首先要掌握两个方法
def draw_networkx_edges(G, pos,
edgelist=None,
width=1.0,
edge_color='k',
style='solid',
alpha=1.0,
edge_cmap=None,
edge_vmin=None,
edge_vmax=None,
ax=None,
arrows=True,
label=None,
**kwds):
G:图表
一个networkx图
pos:dictionary
将节点作为键和位置作为值的字典。
位置应该是长度为2的序列。
edgelist:边缘元组的集合
只绘制指定的边(默认= G.edges())
width:float或float数组
边线宽度(默认值= 1.0)
edge_color:颜色字符串或浮点数组
边缘颜色。可以是单颜色格式字符串(default ='r'),
或者具有与edgelist相同长度的颜色序列。
如果指定了数值,它们将被映射到
颜色使用edge_cmap和edge_vmin,edge_vmax参数。
style:string
边线样式(默认='solid')(实线|虚线|点线,dashdot)
alpha:float
边缘透明度(默认值= 1.0)
edge_ cmap:Matplotlib色彩映射
用于映射边缘强度的色彩映射(默认值=无)
edge_vmin,edge_vmax:float
边缘色图缩放的最小值和最大值(默认值=无)
ax:Matplotlib Axes对象,可选
在指定的Matplotlib轴中绘制图形。
arrows:bool,optional(default = True)
对于有向图,如果为真,则绘制箭头。
label:图例的标签
def draw_networkx_nodes(G, pos,
nodelist=None,
node_size=300,
node_color='r',
node_shape='o',
alpha=1.0,
cmap=None,
vmin=None,
vmax=None,
ax=None,
linewidths=None,
label=None,
**kwds):
G:图表
一个networkx图
pos:dictionary
将节点作为键和位置作为值的字典。
位置应该是长度为2的序列。
ax:Matplotlib Axes对象,可选
在指定的Matplotlib轴中绘制图形。
nodelist:list,可选
只绘制指定的节点(默认G.nodes())
node_size:标量或数组
节点大小(默认值= 300)。如果指定了数组,它必须是
与点头长度相同。
node_color:颜色字符串或浮点数组
节点颜色。可以是单颜色格式字符串(default ='r'),
或者具有与点头相同长度的颜色序列。
如果指定了数值,它们将被映射到
颜色使用cmap和vmin,vmax参数。看到
matplotlib.scatter更多详细信息。
node_shape:string
节点的形状。规格为matplotlib.scatter
标记,'so ^> v
alpha:float
节点透明度(默认值= 1.0)
cmap:Matplotlib色图
色彩映射节点的强度(默认=无)
vmin,vmax:float
节点色彩映射缩放的最小值和最大值(默认值=无)
线宽:[无|标量|序列]
符号边框的线宽(默认值= 1.0)
label:[无|串]
图例的标签
然后基本上所有networkx的超酷精美图的源码你都能快速弄懂了。
以上这篇使用Python的networkx绘制精美网络图教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
python画有权重网络图_使用Python的networkx绘制精美网络图教程相关推荐
- 用python画关系网络图-使用Python的networkx绘制精美网络图教程
最近因为数学建模3天速成Python,然后做了一道网络的题,要画网络图.在网上找了一些,发现都是一些很基础的丑陋红点图,并且关于网络的一些算法也没有讲,于是自己进http://networkx.git ...
- 用python画时序图源代码_使用python实现画AR模型时序图
背景: 用python画AR模型的时序图. 结果: 代码: import numpy as np import matplotlib.pyplot as plt """ ...
- 用python画微信捂脸_用 Python 画一个捂脸表情
微信中的捂脸表情相信大家都不陌生,我见过以及自己使用这个表情的频率都是比较高的,可以说这个表情算是大部分人的主打表情之一了,本文我使用 Python 来画一下这个表情,我们使用到的库还是 turtle ...
- 用python画动态皮卡丘_利用Python绘制萌萌哒的皮卡丘
开发工具 Python版本:3.6.4 相关模块: turtle模块. 环境搭建 安装Python并添加到环境变量即可. 在cmd窗口运行"pikachu.py"文件即可. 效果如 ...
- python画一颗心_利用python画一颗心的方法示例
前言 Python一般使用Matplotlib制作统计图形,用它自己的说法是'让简单的事情简单,让复杂的事情变得可能'.用它可以制作折线图,直方图,条形图,散点图,饼图,谱图等等你能想到的和想不到的统 ...
- python画星空的程序_用python画星空源代码是什么?
用python画星空源代码是什么? 用python画星空源代码是from turtle import * from random import random,randint screen = Scre ...
- 用python画星空的代码_用python画星空源代码是什么?_后端开发
用python画星空源代码是什么? 用python画星空源代码是 from turtle import * from random import random,randint screen = Scr ...
- python画圣诞树代码解读_使用Python画了一棵圣诞树的实例代码
分享给大家一篇文章,教你怎样用Python画了一棵圣诞树,快来学习. 如何用Python画一个圣诞树呢? 最简单: height = 5 stars = 1 for i in range(heig ...
- 用python画小猪佩奇代码_用python画个小猪佩奇(turtle示例源码)
[实例简介]来副小猪佩奇,用python画个小猪佩奇 [实例截图] [核心代码]# coding:utf-8 import turtle as t def nose(x,y):#鼻子 t.pu() t ...
最新文章
- 实现php实现价格的排序,PHP实现二维数组排序(按照数组中的某个字段)
- 深究AngularJS——监听模型$watch
- 第六届 蓝桥杯 省赛 Java B组 牌型总数
- 计算机无法安装系统,一招就能搞定“这台电脑无法安装 Windows 11”的解决方法...
- bpe编码_缓冲池扩展(BPE)–缓冲池简介
- C#图片动画效果(旋转360度)异步
- linux rvm,RVM 实用指南
- 【转载,留作参考】mysql 截取字符串以及mysql update select
- 账龄分析表excel模板_优秀财务的Excel水平!
- C语言学习7:ASCII码表及用法简介
- JAVAME 还有钱途么?
- 故宫回应灯会票秒光:3500人约成功 没票别信黄牛
- Unhandled rejection Error: EACCES: permission denied, open '/Users
- c语言达内月考试题,达内C培训第一次月考〔附答案〕.doc
- 专科学习计算机应用需要学的课本,计算机应用技术
- 假冒Macbook充电器拆解:外表令人信服但内部却非常危险
- java添加窗体中_java中利用JFrame创建窗体 【转】
- 机器学习在无线信道建模中的应用现状与展望
- 【Java】Java的垃圾回收
- IDEA快捷键CTRL+ALT+L格式化失效
热门文章
- GitHub被“中介”攻击了?中间人攻击?
- 从1行代码到20万行开源,我已经走过了三年
- 微信网站-微信应用-微信二次开发-演示方案
- SpringBoot2.0 基础案例(03):配置系统全局异常映射处理
- ResNet在分别在Keras和tensorflow框架下的应用案例
- 从容 IT 人生路,开发工具伴我行——“葡萄城 30 周年”征文
- js 负数移位运算究竟如何进行
- Linux文本查看命令之cat
- 10 条真心有趣的 Linux 命令
- yii2 rbac权限控制之菜单menu详细教程