小书匠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. vue的安装配置与项目创建

    1,安装vue必须先安装node.js.  --------去官网安装node.js 因为npm依赖node.js环境,使用npm的时候需要安装node.js.安装node.js的时候npm会默认安装 ...

  2. Java基础IO类之File类

    大三了,目前基础太差了,重新学习过!代码如下,里面都有详细的解释每一行代码代表的意思~ package IODemo; import java.io.File; import java.io.File ...

  3. Spring Boot的配置文件-yml文件的集合配置方式

    yml集合数据的表示方式: 这种方式是配置普通的字符串—— 如果集合中装的是对象,就这么配置—— 行内配置方式—— map的配置方式——

  4. Python之原始数据-1

    一.数据对于模型来说是基础,是数据成就了模型,而现在的又是一个数据时代,比如:淘宝等.通过对用户数据的分析挖掘,预测用户的消费习惯等,再比如:人工智能.通过提取摄像头的图片帧数,通过分析图片,得出具体 ...

  5. CTR预估-GBDT与LR实现

    1.来源 本质上 GBDT+LR 是一种具有 stacking 思想的二分类器模型,所以可以用来解决二分类问题.这个方法出自于 Facebook 2014 年的论文 Practical Lessons ...

  6. 错误 4 error C2039: “Sleep”: 不是“boost::this_thread”的成员

    检查是否是在x64下运行的. #include <pcl/io/openni2_grabber.h> #include <pcl/visualization/cloud_viewer ...

  7. array_map 去除数组参数里面左右两端空格

    <?php class Test{ public function trimArray($params){ if (!is_array($params)) return trim($params ...

  8. SDL -安全开发生命周期

    1.学习SDL https://www.cnblogs.com/whoami101/p/9914862.html 2.学习SDL https://blog.csdn.net/whatday/artic ...

  9. Yarn介绍(设计理念与基本架构)

    Yarn : 新的计算框架,是一个全局资源管理器,负责整个集群的资源管理和分配   一. Yarn产生背景       Hadoop1.0MR有局限性,概括为以下几个方面 :  扩展性差 可靠性差 资 ...

  10. Android笔记(十八) 下拉列表(Spinner)

    App中常用的控件——下拉列表(Spinner),提供特定选择供用户选择 Spinner每次只能选择一个部件,它的选项来自于与之相关联的适配器(apater)中. MainActivity.java ...