NetworkX系列教程(6)-对graph进行操作
graph生成后,除了有查看操作,还有移除等操作,还有其他更多操作,具体可以看这里.下面将比较graph操作前后的不同.
目录:
注意:如果代码出现找不库,请返回第一个教程,把库文件导入.
7.对图进行操作
7.1移除某些节点和边
- #G.clear()
- #生成graph
- G=nx.path_graph(8)
- plt.subplots(1,2,figsize=(15,5))
- plt.suptitle('移除部分节点和边',fontproperties=myfont)
- #画出未操作前的graph
- plt.subplot(121)
- nx.draw(G, with_labels=True, font_weight='bold')
- plt.title('操作前',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- #移除部分节点和边,移除所有的点和边使用G.clear(),不再单独测试
- G.remove_node(2)
- G.remove_nodes_from([1,5])
- G.remove_edge(3, 4)
- #画出操作后的graph
- plt.subplot(122)
- nx.draw(G, with_labels=True, font_weight='bold')
- plt.title('操作后',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- #显示graph
- plt.show()

7.2合并graph
- # G1.clear()
- # G2.clear()
- # G3.clear()
- plt.subplots(1,3,figsize=(15,5))
- plt.suptitle('合并两个图',fontproperties=myfont)
- #生成graph1
- G1=nx.path_graph(8)
- plt.subplot(131)
- nx.draw(G1, with_labels=True, font_weight='bold')
- plt.title('图1',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- #生成graph2
- G2=nx.complete_graph(3)
- plt.subplot(132)
- nx.draw(G2, with_labels=True, font_weight='bold')
- plt.title('图2',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- #移除部分节点和边,移除所有的点和边使用G.clear(),不再单独测试
- G3=nx.disjoint_union(G1,G2)
- plt.subplot(133)
- nx.draw(G3, with_labels=True, font_weight='bold')
- plt.title('合并后',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- #显示graph
- plt.show()

7.3有向图和无向图的转化
- #无向图转有向图
- plt.subplots(1,2,figsize=(15,3))
- plt.suptitle('无向图转换为有向图',fontproperties=myfont)
- #定义无向图
- G = nx.path_graph(8)
- #转换为有向图
- G2=G.to_directed()
- #下面是可视化转换前后的两个图
- plt.subplot(121)
- nx.draw(G, with_labels=True, font_weight='bold')
- plt.title('无向图',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- plt.subplot(122)
- nx.draw(G2, with_labels=True, font_weight='bold')
- plt.title('有向图',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- plt.show()
- plt.close()
- #有向图转无向图
- G.clear()
- G2.clear()
- plt.subplots(1,2,figsize=(15,3))
- plt.suptitle('有向图转换为无向图',fontproperties=myfont)
- #定义有向图
- G = nx.path_graph(8,create_using=nx.DiGraph())
- #转换为无向图
- G2=G.to_undirected()
- #下面是可视化转换前后的两个图
- plt.subplot(121)
- nx.draw(G, with_labels=True, font_weight='bold')
- plt.title('有向图',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- plt.subplot(122)
- nx.draw(G2, with_labels=True, font_weight='bold')
- plt.title('无向图',fontproperties=myfont)
- plt.axis('on')
- plt.xticks([])
- plt.yticks([])
- plt.show()
- # 注:可以看出无向图转有向图时,得到的边都是双向


NetworkX系列教程(6)-对graph进行操作的更多相关文章
- NetworkX系列教程(1)-创建graph
小书匠Graph图论 研究中经常涉及到图论的相关知识,而且常常面对某些术语时,根本不知道在说什么.前不久接触了NetworkX这个graph处理工具,发现这个工具已经解决绝大部分的图论问题(也许只是我 ...
- NetworkX系列教程(8)-Drawing Graph
小书匠Graph图论 如果只是简单使用nx.draw,是无法定制出自己需要的graph,并且这样的graph内的点坐标的不定的,运行一次变一次,实际中一般是要求固定的位置,这就需要到布局的概念了.详细 ...
- NetworkX系列教程(7)-对graph进行分析
小书匠Graph图论 graph构建完成后,对graph的连通等属性进行分析. 目录: 8.对图进行分析 8.1连通子图 8.2弱联通 8.3强连通 8.4子图 8.5条件过滤 注意:如果代码出现找不 ...
- NetworkX系列教程(5)-查看graph的信息
小书匠Graph图论 有时候graph建好后,我们并不清除该graph内节点的,边的信息,这就需要调用函数去查看了. 目录: 6.查看Graph的信息 6.1查看graph内节点,边的 6.2查看gr ...
- NetworkX系列教程(4)-设置graph的信息
小书匠Graph图论 要画出美观的graph,需要对graph里面的节点,边,节点的布局都要进行设置,具体可以看官方文档:Adding attributes to graphs, nodes, and ...
- 【原创】【2】rich editor系列教程。了解document.execommand操作,保存丢失的range,实时反馈样式给工具栏
[原创][2]rich editor系列教程.了解document.execommand操作,保存丢失的range,实时反馈样式给工具栏 索引目录:http://www.cnblogs.com/hen ...
- NetworkX系列教程(2)-graph生成器
小书匠Graph图论 本节主要讲解如何快速使用内置的方法生成graph,官方的文档在这里,里面包含了networkX的所有graph生成器,下面的内容只是我节选的内容,并将graph画出来而已. 声明 ...
- NetworkX系列教程(11)-graph和其他数据格式转换
小书匠 Graph 图论 学过线性代数的都了解矩阵,在矩阵上的文章可做的很多,什么特征矩阵,单位矩阵等.grpah存储可以使用矩阵,比如graph的邻接矩阵,权重矩阵等,这节主要是在等到graph后 ...
- NetworkX系列教程(3)-手动创建graph
小书匠Graph图论 不可否认,日常中我们使用最多的还是,使用自己的数据去手动创建自己的图形,而不是使用生成器,现从给graph添加点和边入手,讲解手动创建graph. 目录: 3.给graph添加节 ...
随机推荐
- PEB TEB结构体使用
PEB TEB结构体使用一个可执行文件被OS加载到内存,并处理完成相关的模块加载,导入表处理……及其他必须处理后,形成一个进程.在OS内核中保存有一份关于这个进程的身份证信息,就是平常看到的HANDL ...
- 杭电1253 超时的bfs...
#include<stdio.h>#include<iostream>#include<string.h>#include<algorithm>usin ...
- WSL 服务自动启动
WSL 服务自动启动 参考 https://zhuanlan.zhihu.com/p/47733615 Windows 启用 WSL 功能支持 > Enable-WindowsOptionalF ...
- C++实现企业链表(单向链表的另外一种实现方式)
LinkList.h #include <windows.h> #include <stdio.h> // 链表小结点 typedef struct LINKNODE { LI ...
- [LeetCode] 671. 二叉树中第二小的节点 ☆(递归 合并)
描述 给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2 或 0.如果一个节点有两个子节点的话,那么这个节点的值不大于它的子节点的值. 给出这样的一个二叉树,你需要输出所有 ...
- shell 大型脚本工具开发实战
拆分脚本功能,抽象函数 1.function get_all_group 返回进程组列表字符串 2.function get_all_process 返回进程名列表字符串"nginx htt ...
- 【Distributed】分布式解决方案【汇总】
一.问题引出 二.分布式Session问题 三.网站跨域问题 四.分布式任务调度平台 五.分布式配置中心 六.分布式锁解决方案 七.缓存技术 一.问题引出 [Distributed]分布式系统中遇到的 ...
- JAVA 查找某个目录是否存在,如果存在,打印出来
题目:现有如下目录结构,查找结构中是否存在Directory11,如果存在,打印出来 |---test |---|---Directory1 |---|---|---Directory11 |---| ...
- Linux命令——ulimit
参考:https://www.cnblogs.com/kongzhongqijing/p/5784293.html
- 每日一题-——LeetCode(121)买卖股票的最佳时机
题目描述: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格.如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润.注意你不能在买入股票前卖出股票 ...