小书匠Graph图论

不可否认,日常中我们使用最多的还是,使用自己的数据去手动创建自己的图形,而不是使用生成器,现从给graph添加和边入手,讲解手动创建graph.

目录:


注意:如果代码出现找不库,请返回第一个教程,把库文件导入.

3.给graph添加节点

  1. from math import ceil 


  2. #该函数由于显示一组graph,传上来的是一组graph和这些graph的描述. 

  3. def ShowGraph(glists,ginfo,rowsize=4): 


  4. #每行放rowsize个,计算可以放多少行 

  5. row=ceil(len(glists)/rowsize) 


  6. #定义组图 

  7. plt.subplots(row,rowsize,figsize=(15,3)) 


  8. #开始画图 

  9. for ind in range(len(glists)): 

  10. #定义子图 

  11. plt.subplot(row,rowsize,ind+1) 

  12. nx.draw(glists[ind],with_labels=True, font_weight='bold') 


  13. #设置图片 

  14. plt.title(ginfo[ind],fontproperties=myfont) 

  15. plt.axis('on') 

  16. plt.xticks([]) 

  17. plt.yticks([]) 

  18. plt.show() 

  1. #添加单个节点 

  2. G1=nx.Graph() 

  3. G1.add_node(1) 

  4. G1.add_node("spam") 


  5. #添加一组节点 

  6. G2=nx.Graph() 

  7. G2.add_nodes_from([2, 3]) 

  8. G2.add_nodes_from("spam") 


  9. #使用生成器 

  10. G3=nx.Graph() 

  11. H = nx.path_graph(10) 

  12. G3.add_nodes_from(H) 


  13. #注意:G1.add_nodes_from(H)表示用H中的节点表示G1这个graph,如果要往G1这个graph添加H这个graph,形成graph中的graph,可以使用以下命令 

  14. G4= nx.Graph() 

  15. G4.add_node(1) 

  16. G4.add_node(H) 


  17. glists=[G1,G2,G3,G4] 

  18. ginfo=['添加单个节点','添加一组节点','使用生成器','添加子图'] 

  19. ShowGraph(glists,ginfo) 


给graph添加节点

4.给graph添加边

  1. #删除前面的graph 

  2. G1.clear() 

  3. G2.clear() 

  4. G3.clear() 

  5. G4.clear() 


  6. #添加单边 

  7. G1=nx.Graph() 

  8. G1.add_edge(1,2) 

  9. G1.add_edge(3, 'm') 


  10. #添加一组边 

  11. G2=nx.Graph() 

  12. e=(2,3) 

  13. G2.add_edge(*e) 


  14. #添加多组边 

  15. G3=nx.Graph() 

  16. G3.add_edges_from([(3,4),(4,2)]) 


  17. #使用边生成器 

  18. G4= nx.Graph() 

  19. H = nx.path_graph(10) 

  20. G4.add_edges_from(H.edges) 


  21. #添加一组有权边 

  22. G5=nx.Graph() 

  23. G5.add_weighted_edges_from([('a', 'b', 5.0), ('b', 'c', 3.0), ('a', 'c', 1.0), ('c', 'd', 7.3)]) #边上权重显示看设置graph信息->指定边属性 


  24. glists=[G1,G2,G3,G4,G5] 

  25. ginfo=['添加单边','添加一组边','添加多组边','使用边生成器','添加一组有权边'] 

  26. ShowGraph(glists,ginfo,rowsize=5) 


给graph添加边

NetworkX系列教程(3)-手动创建graph的更多相关文章

  1. NetworkX系列教程(1)-创建graph

    小书匠Graph图论 研究中经常涉及到图论的相关知识,而且常常面对某些术语时,根本不知道在说什么.前不久接触了NetworkX这个graph处理工具,发现这个工具已经解决绝大部分的图论问题(也许只是我 ...

  2. NetworkX系列教程(11)-graph和其他数据格式转换

    小书匠 Graph 图论  学过线性代数的都了解矩阵,在矩阵上的文章可做的很多,什么特征矩阵,单位矩阵等.grpah存储可以使用矩阵,比如graph的邻接矩阵,权重矩阵等,这节主要是在等到graph后 ...

  3. NetworkX系列教程(4)-设置graph的信息

    小书匠Graph图论 要画出美观的graph,需要对graph里面的节点,边,节点的布局都要进行设置,具体可以看官方文档:Adding attributes to graphs, nodes, and ...

  4. NetworkX系列教程(8)-Drawing Graph

    小书匠Graph图论 如果只是简单使用nx.draw,是无法定制出自己需要的graph,并且这样的graph内的点坐标的不定的,运行一次变一次,实际中一般是要求固定的位置,这就需要到布局的概念了.详细 ...

  5. NetworkX系列教程(2)-graph生成器

    小书匠Graph图论 本节主要讲解如何快速使用内置的方法生成graph,官方的文档在这里,里面包含了networkX的所有graph生成器,下面的内容只是我节选的内容,并将graph画出来而已. 声明 ...

  6. NetworkX系列教程(7)-对graph进行分析

    小书匠Graph图论 graph构建完成后,对graph的连通等属性进行分析. 目录: 8.对图进行分析 8.1连通子图 8.2弱联通 8.3强连通 8.4子图 8.5条件过滤 注意:如果代码出现找不 ...

  7. NetworkX系列教程(6)-对graph进行操作

    小书匠Graph图论 graph生成后,除了有查看操作,还有移除等操作,还有其他更多操作,具体可以看这里.下面将比较graph操作前后的不同. 目录: 7.对图进行操作 7.1移除某些节点和边 7.2 ...

  8. NetworkX系列教程(5)-查看graph的信息

    小书匠Graph图论 有时候graph建好后,我们并不清除该graph内节点的,边的信息,这就需要调用函数去查看了. 目录: 6.查看Graph的信息 6.1查看graph内节点,边的 6.2查看gr ...

  9. NetworkX系列教程(10)-算法之五:广度优先与深度优先

    小书匠Graph图论 重头戏部分来了,写到这里我感觉得仔细认真点了,可能在NetworkX中,实现某些算法就一句话的事,但是这个算法是做什么的,用在什么地方,原理是怎么样的,不清除,所以,我决定先把图 ...

随机推荐

  1. 括号匹配问题 —— Deque双端队列解法

    题目: 给定一个只包括 '(',')','{','}','[',']'?的字符串,判断字符串是否有效. 有效字符串需满足: 左括号必须用相同类型的右括号闭合.左括号必须以正确的顺序闭合.注意空字符串可 ...

  2. windows下mysql表名区分大小写

    windows下mysql默认是不区分大小写的,但是linux会区分大小写 如何让windows下mysql区分大小写呢? 修改 my.ini 里面的mysqld部分 #区分大小写 lower_cas ...

  3. Visual Web Developer 2012安裝教程

    1.打开网页链接http://www.w3school.com.cn/aspnet/mvc_intro.asp 点击Visual Web Developer 2012进行安装安装平台(WebPlatf ...

  4. IO中断

    >>>io的中断编程 以上例程会有什么问题呢? 注意:CPU内部寄存器

  5. Centos 配置eth0 提示Device does not seem to be present -- 转载

    http://www.cnblogs.com/fbwfbi/archive/2013/04/29/3050907.html 移动虚拟机造成网卡无法识别 一.故障现象: [root@c1node01 ~ ...

  6. 树莓派手动设置静态IP和DNS方法

    在使用树莓派的过程中,往往需要手动设置一个静态的IP地址,一来可以防止DHCP自动分配的IP变动,二来可提高树莓派的网络连接速度.查看官方文档 man dhcpcd.conf可知,需要配置静态IP的话 ...

  7. Java 之 网络编程基础

    一.软件结构 C/S 结构:全称为 Client/Server 结构,是指客户端和服务器结构.常见的程序有微信,QQ,迅雷等软件. B/S 结构:全称 Brower/Server 结构,是指浏览器和服 ...

  8. Javascript的异步与单线程

    一.前言 我们都知道,javasript是一个单线程的语言:所谓单线程就是同一时间不能做两件事情,两段代码不能同时执行:因为这种机制,才避免了两段js同时对一个DOM节点进行渲染的冲突.但是也会因此产 ...

  9. JAVA笔记整理(六),JAVA中的多态

    JAVA引用变量有两个类型:一个是编译时类型,一个运行时类型 编译时类型由声明该变量时使用的类型决定,运行时类型由实际赋给该变量的对象决定.如果编译时类型和运行时类型不一样,就形成了多态. 因为子类其 ...

  10. HDU-5728-PowMod-求phi(i*n)前缀和+指数循环节

    HDU-5728-PowMod-求phi(i*n)前缀和+指数循环节 [Problem Description] 令\(k=\sum_{i=1}^m \varphi(i\cdot n)\ mod \ ...