networkX用法整
无向图,有向图,加权图等例子代码 【http://www.cnblogs.com/kaituorensheng/p/5423131.html#_label1】
数据分析学习笔记(三)-NetworkX的使用 【http://baiyejianxin.iteye.com/blog/1764048】
官网文档 【https://networkx.readthedocs.io/en/stable/overview.html】 【http://networkx.github.io/documentation/networkx-1.7/index.html】
NetworkX使用笔记:读入外部文件并转换成各种格式 【http://sparkandshine.net/networkx-use-notes-read-external-file-convert-to-other-formats/】
————————————————————————————————-
1.安装
安装networkx之前要安装画图工具matplotlib,以及矩阵运算工具numpy,于是我们执行:
pip install numpy
pip install matplotlib
pip install networkx
2.使用
networkx的英文版说明可以在其官方网站上下载得到,写的简单易懂。
http://networkx.github.io/documentation/latest/reference/index.html
这里记录下一些简单的建图方法。
在networkx中,图以对象的形式提供借口。
在图对象中,还有点,边等也是以对象形式提供,画图则调用matplotlib的函数完成。
建图
networkx可以建立简单无向图graph,有向图digraph,可重复边的multi-graph。
import networkx as nx
G=nx.Graph()
D=nx.DiGraph()
M=nx.MultiGraph()
点
这里的点可以是任意可区分的对象(hashable),比如数字,字符串,对象等。
G.add_node(1)
G.add_node('first_node’) #这里用一个对象多为key来唯一区别一个点 #我们还能够用一个列表来批量加入点
G.add_nodes_from([1,2,3]) #还可以用一个图对象作为点,嵌入到其他图中
G.add_node(D) #这里D作为一个点的key #或者把一个图的所有点赋予另一个图
G.add_nodes_from(D) #这里返回D的所有点,赋予G #与加入相同的传递方法,我们也可以删除点
G.remove_node(1)
G.remove_nodes_from([1,2,3])
边
这里的边可以使用两个单独的对象作为输入
G.add_edge(1,2) #表示1,2之间有一条边。 #如果不存在点1,2,则会自动加入点集合。 #或者以元组的形式作为输入
e=(1,2)
G.add_edge(e) #这里的代表吧元组解包(unpack),当作一个个的值扔到函数中去。 #如果不解包,等价于 #G.add_edge(e)=G.add_edge((1,2))与参数传递的方式不符。 #类似的,我们还可以使用包含元组的列表来传递参数
G.add_edges_from([(1,2),(2,3)]) #我们还可以报一个图的边赋予另一个图
G.add_edges_from(H) #删除
G.remove_edge(1,2)
G.remove_edges_from([(1,2),(2,3)])
访问
node_list = G.nodes()
edge_list = G.edges() #可以返回包含点与边的列表
node = G.node[‘first_node’] #如上根据key返回点
edge = G.edge['first_node’]['second_node’] #同样的方法,返回两个key之间的边
属性
我们可以给图,点,边赋予各种属性,最简单的就是权值属性
G.add_node(1,time='5pm’) #在添加时跟上属性
G.add_nodes_from([1,2,3],time='5pm’) #批量添加点是,跟上统一的属性
G.add_nodes_from([(3,{'time’:'5pm’}), (4,{'time’:'4pm’})]) #或者写成元组列表[(key,dict),(key,dict)]的形式
G.node1['time’] #根据字典key访问属性值。
给边添加属性也类似
G.add_edge(1,2,time='3am’)
G.add_edges_from([(1,2,{'time’='5pm’}),(2,3,{'time’=3am})]) #批量赋予属性
G.edge1[2][‘time’] #访问
我们还可以使用特定的函数批量返回属性,如
time = nx.get_edge_attributes(G,'time’) #返回得到以元组为key,time属性为值得一个字典
time[(1,2)]
图算法
nx.connected_components(G) #返回列表形式的G的全连通分量,每个分量一个子列表
类似的,networkx还提供各种图算法,具体可见官方文档。
画图
nx.draw(G) #画出图G
matplotlib.show() #显示出来
————————————————————————————————-
import networkx as nx
import matplotlib.pyplot as plt
计算1:求无向图的任意两点间的最短路径
G = nx.Graph()
G.add_edges_from([(1,2),(1,3),(1,4),(1,5),(4,5),(4,6),(5,6)])
path = nx.all_pairs_shortest_path(G)
print(path1)
计算2:求出图中在环上的点
G = nx.Graph()
G.add_edges_from([(1,2),(1,3),(1,4),(1,5),(4,5),(4,6),(5,6)])
path = nx.all_pairs_shortest_path(G)
print(path1)
path=nx.all_pairs_shortest_path(G) #调用多源最短路径算法,计算图G所有节点间的最短路径
print(path0[2]) #输出节点0、2之间的最短路径序列: [0, 1, 2]
networkX用法整的更多相关文章
- 关于SqlServer表结构 2(回归基础)
关于SqlServer表结构的问题.先来了解一下SqlServer中的数据类型以及它们的用法 整型: 短整型 smallint 整型 int 长整型 bitint 标识列:identity(它是只读的 ...
- TreeViewItem实现整行选中 (两种用法)
用法一 <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation&quo ...
- 【ABAP系列】SAP ABAP模块-取整操作中CEIL和FLOOR用法
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP模块-取整操作中 ...
- go中整型的用法小结
示例 // 整型的用法小结 // 注意: // 整型变量在使用时,遵循保小不保大的原则 // 尽量使用占用空间小的数据类型 package main import ( "fmt" ...
- [C]基本数据类型:整型(int)用法详解
1.整型int C语言提供了很多整数类型(整型),这些整型的区别在于它们的取值范围的大小,以及是否可以为负.int是整型之一,一般被称为整型.以后,在不产生歧义的情况下,我们把整数类型和int都称为整 ...
- python中的数字取整(ceil,floor,round)概念和用法
python中的数学运算函数(ceil,floor,round)的主要任务是截掉小数以后的位数.总体来说 就是取整用的.只是三者之间有微妙的区别: floor() :把数字变小 ceil() : ...
- Handlebars的基本用法 Handlebars.js使用介绍 http://handlebarsjs.com/ Handlebars.js 模板引擎 javascript/jquery模板引擎——Handlebars初体验 handlebars.js 入门(1) 作为一名前端的你,必须掌握的模板引擎:Handlebars 前端数据模板handlebars与jquery整
Handlebars的基本用法 使用Handlebars,你可以轻松创建语义化模板,Mustache模板和Handlebars是兼容的,所以你可以将Mustache导入Handlebars以使用 Ha ...
- python下的复杂网络编程包networkx的使用(摘抄)
原文:http://blog.sciencenet.cn/home.php?mod=space&uid=404069&do=blog&classid=141080&vi ...
- Webform:Session、Cookie对象的用法
Session 优点:1.使用简单,不仅能传递简单数据类型,还能传递对象. 2.数据量大小是不限制的. 缺点:1.在Session变量存储大量的数据会消耗较多的服务器资源. 2.容易丢失. 使用方法 ...
随机推荐
- Linux命令 改变文档权限及所有者
Linux命令 改变文档权限及所有者 chgrp :改变档案所属群组 chown :改变档案拥有者 chmod :改变档案的权限, SUID, SGID, SBIT等等的特性 chgrp说明及范例 [ ...
- 浅谈浅克隆(shallow clone)和 深克隆(deep clone)
区别就在于是否对对象中的引用变量所指向的对象进行拷贝. 1.浅克隆/浅复制/浅拷贝 浅拷贝是指在拷贝对象时,对于基本数据类型的变量会重新复制一份,而对于引用类型的变量只是对引用进行拷贝,没有对引用指向 ...
- rtmp 推送h264 + aac 的数据
相关源码下载: http://download.csdn.net/detail/keepingstudying/8340431 需要libfaac,librtmp 的支持, 1.帧的划分 1.1 H. ...
- java代码----大二上机考试
总结:对 冒泡排序熟悉,但不能灵活插入代码 package com.dkl; import java.io.*; import java.io.IOException; import java.uti ...
- 通过socket实现处理多个连接,send和resv都是有数量限制的
我们现在先来实现,跟一个人来来回回不停的讲电话. 客户端,通过循环来输入多次命令: client.recv(1024)每次只接收1K的内容 服务端来改成多次接收:如果你写成如下的代码: 那么造成的结果 ...
- PHP for和foreach的区别
首先,我们先准备两个用于遍历的数组: $arr1=array(1=>'a', 3=>22, 5=>'b', 4=>'c', 8=>'d'); $arr2=array('a ...
- 关于sencha touch中给文本添加焦点无效的解决方案
目前的解决方案是给你的执行代码加上一个timeout延迟100ms+ setTimeout(function(){ SoftKeyboard.isShowing(function(isShowing) ...
- java并发的基本概念和级别
并发的概念: 并发(Concurrency)和并行(Parallelism) 并发偏重于多个任务交替执行,而多个任务之间有可能还是串行的.而并行是真正意义上的“同时执行”.严格意义上来说,并行的多个任 ...
- Flask之模板之控制语句
3.4 控制语句 常用的几种控制语句: 模板中的if控制语句 @app.route('/user') def user(): user = 'dongGe' return render_templat ...
- 在Android Studio 0.5.2中使用ArcGIS Android SDK
环境 操作系统:Mac OSX 10.8.5Android Studio: 0.5.2ArcGIS Android SDK: 10.2.3 操作步骤 在Android Studio中新建一个Modul ...