欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python Matplotlib 基于networkx畫關(guān)系網(wǎng)絡(luò)圖

 更新時(shí)間:2019年07月10日 09:33:21   作者:roguesir  
這篇文章主要介紹了Python Matplotlib 基于networkx畫關(guān)系網(wǎng)絡(luò)圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

昨天才開(kāi)始接觸,鼓搗了一個(gè)下午,接下來(lái)會(huì)持續(xù)更新,如果哪里有錯(cuò)誤的地方,望各位大佬指出,謝謝!

數(shù)據(jù)描述

兩個(gè)文件,一個(gè)文件包含了網(wǎng)絡(luò)圖的節(jié)點(diǎn),節(jié)點(diǎn)存在類別(0,1,2,3)四類,但是0類別舍去,不畫出;另一個(gè)文件包含了網(wǎng)絡(luò)圖的邊,數(shù)據(jù)基本特征如下:

             

圖1中,id表示節(jié)點(diǎn),b是類別;圖2中,兩個(gè)數(shù)字表示邊連接的兩個(gè)點(diǎn)。

Networkx

安裝

我的系統(tǒng)是Mac OS,直接在terminal輸入sudo pip install networkx就可以安裝,由于代碼中涉及幾個(gè)函數(shù),在python3中會(huì)報(bào)錯(cuò),我用python2.7.13實(shí)現(xiàn)的

基本使用方法

import networkx as nx          #導(dǎo)入networkx包
import matplotlib.pyplot as plt   #導(dǎo)入繪圖包matplotlib(需要安裝,方法見(jiàn)第一篇筆記)
G =nx.random_graphs.barabasi_albert_graph(100,1)  #生成一個(gè)BA無(wú)標(biāo)度網(wǎng)絡(luò)G
nx.draw(G)             #繪制網(wǎng)絡(luò)G
plt.savefig("ba.png")      #輸出方式1: 將圖像存為一個(gè)png格式的圖片文件
plt.show()              #輸出方式2: 在窗口中顯示這幅圖像

參數(shù)介紹基本

- `node_size`: 指定節(jié)點(diǎn)的尺寸大小(默認(rèn)是300,單位未知,就是上圖中那么大的點(diǎn))
- `node_color`: 指定節(jié)點(diǎn)的顏色 (默認(rèn)是紅色,可以用字符串簡(jiǎn)單標(biāo)識(shí)顏色,例如'r'為紅色,'b'為綠色等,具體可查看手冊(cè))
- `node_shape`: 節(jié)點(diǎn)的形狀(默認(rèn)是圓形,用字符串'o'標(biāo)識(shí),具體可查看手冊(cè))
- `alpha`: 透明度 (默認(rèn)是1.0,不透明,0為完全透明)
- `width`: 邊的寬度 (默認(rèn)為1.0)
- `edge_color`: 邊的顏色(默認(rèn)為黑色)
- `style`: 邊的樣式(默認(rèn)為實(shí)現(xiàn),可選: solid|dashed|dotted,dashdot)
- `with_labels`: 節(jié)點(diǎn)是否帶標(biāo)簽(默認(rèn)為True)
- `font_size`: 節(jié)點(diǎn)標(biāo)簽字體大小 (默認(rèn)為12)
- `font_color`: 節(jié)點(diǎn)標(biāo)簽字體顏色(默認(rèn)為黑色)

布局

  • circular_layout:節(jié)點(diǎn)在一個(gè)圓環(huán)上均勻分布
  • random_layout:節(jié)點(diǎn)隨機(jī)分布
  • shell_layout:節(jié)點(diǎn)在同心圓上分布
  • spring_layout: 用Fruchterman-Reingold算法排列節(jié)點(diǎn)
  • spectral_layout:根據(jù)圖的拉普拉斯特征向量排列節(jié)點(diǎn)

代碼

# coding:utf-8
 
 
import networkx as nx 
import matplotlib.pyplot as plt
import csv
 
with open('node-8.csv','rb') as csvfile:
	reader = csv.DictReader(csvfile)
	column = [row['b'] for row in reader]
	id_tag0 = [row['id'] for row in reader]
#print column
id_tag = []
for item in id_tag0:
	id_tag.append(int(item))
 
# =================Setting node parameters====================
node_0 = []
node_1 = []
node_2 = []
node_3 = []
node_color = []
node_color_y = []
node_color_r = []
node_color_g = []
node_color_b = []
node_shape = []
node_shape_0 = []
node_shape_1 = []
node_shape_2 = []
node_shape_3 = []
 
for i in range(len(column)):
	if int(column[i]) == 0:
		pass
	elif int(column[i]) == 1:
		color = 'r'
		shape = 'o'
		node_1.append(i)
		node_color_r.append(color)
		node_shape_1.append(shape)
	elif int(column[i]) == 2:
		color = 'g'
		shape = 'o'
		node_2.append(i)
		node_color_g.append(color)
		node_shape_2.append(shape)
	else:
		color = 'b'
		shape = '*'
		node_3.append(i)
		node_color_b.append(color)
		node_shape_3.append(shape)
	node_color.append(color)
	node_shape.append(shape)
# ==============================================================
 
 
with open('node-8.csv','rb') as csvfile:
	reader = csv.DictReader(csvfile)
	column1 = [row['b'] for row in reader]
	id_tag1 = [row['id'] for row in reader]
#print column
id_tag11 = []
for item in id_tag1:
	id_tag11.append(int(item))
 
 
 
edge = []
with open('edge-8.txt','r') as f: 
	data = f.readlines() 
	for line in data:
		#print line
		line = tuple(line.replace('\r','').replace('\n','').replace('\t','').split(','))
		edge.append(line)
#print edge
 
# ===============Setting edge parameters=========================
edge_color = []
edge_style = []
 
for item in edge:
	#print item
	if int(column1[int(item[0])]) == 0 or int(column1[int(item[1])]) == 0:
		pass
	elif int(column1[int(item[0])]) == 1 or int(column1[int(item[1])]) == 1:
		color = 'r'
		#style0 = 'dashdot'
		#color_r_list.append(color)
	elif int(column1[int(item[0])]) == 2 or int(column1[int(item[1])]) == 2:
		color = 'g'
		#style0 = 'dashed'
		#color_r_list.append(color)
	else:
		color = 'b'
		#style0 = 'dotted'
		#color_b_list.append(color)
	edge_color.append(color)
	#edge_style.append(style0)
 
 
G = nx.Graph()
#G.add_nodes_from(id_tag)
G.add_edges_from(edge)
 
#nx.draw(G,pos=nx.random_layout(G), nodelist = node_0, node_color = node_color_y, node_size=120, node_shape=node_shape_0)
#nx.draw(G,pos=nx.random_layout(G), nodelist = node_1, node_color = node_color_r, node_size=120, node_shape=node_shape_1)
#nx.draw(G,pos=nx.random_layout(G), nodelist = node_2, node_color = node_color_g, node_size=120, node_shape=node_shape_2)
#nx.draw(G,pos=nx.random_layout(G), nodelist = node_3, node_color = node_color_b, node_size=120, node_shape=node_shape_3)
 
nx.draw_networkx(G,pos=nx.random_layout(G),node_color=node_color,node_size=10,node_shape='o',edge_color=edge_color,width=0.3,style='solid',font_size=8) 
#nx.draw_networkx(G,pos=nx.random_layout(G),nodelist = node_1,node_color=node_color,node_size=100,node_shape='o',style='dashdot') 
#nx.draw_networkx(G,pos=nx.random_layout(G),node_color=color_g_list,node_size=150,node_shape='^',style='dashed') 
#nx.draw_networkx(G,pos=nx.random_layout(G),node_color=color_b_list,node_size=150,node_shape='*',style='dotted') 
 
#plt.legend()
#nx.draw_networkx(G)
plt.show()

畫圖


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Nginx+Uwsgi+Django 項(xiàng)目部署到服務(wù)器的思路詳解

    Nginx+Uwsgi+Django 項(xiàng)目部署到服務(wù)器的思路詳解

    這篇文章主要介紹了Nginx+Uwsgi+Django 項(xiàng)目部署到服務(wù)器的思路,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Python實(shí)現(xiàn)測(cè)試磁盤性能的方法

    Python實(shí)現(xiàn)測(cè)試磁盤性能的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)測(cè)試磁盤性能的方法,涉及Python對(duì)硬件的相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • 一文帶你掌握Matplotlib圖形繪制

    一文帶你掌握Matplotlib圖形繪制

    Matplotlib是一個(gè)基于Python的繪圖庫(kù),它提供了一整套與Matlab相似的命令A(yù)PI,非常適合交互式繪圖,這篇文章主要給大家介紹了關(guān)于Matplotlib圖形繪制的相關(guān)資料,需要的朋友可以參考下
    2023-09-09
  • 一小時(shí)快速入門Python教程

    一小時(shí)快速入門Python教程

    這篇文章主要講述了幾個(gè)例子,通過(guò)簡(jiǎn)單的demo讓有寫代碼經(jīng)驗(yàn)的你能夠快速的入門Python的使用,大大提升你的學(xué)習(xí)效率
    2021-06-06
  • 測(cè)試、預(yù)發(fā)布后用python檢測(cè)網(wǎng)頁(yè)是否有日常鏈接

    測(cè)試、預(yù)發(fā)布后用python檢測(cè)網(wǎng)頁(yè)是否有日常鏈接

    難免會(huì)碰到秀逗了把測(cè)試的鏈接發(fā)布到線上的情況,一般這種都是通過(guò)一些測(cè)試的檢查工具來(lái)檢查鏈接來(lái)規(guī)避風(fēng)險(xiǎn)的,下面為大家簡(jiǎn)述下大概的實(shí)現(xiàn)思路
    2014-06-06
  • python進(jìn)階教程之模塊(module)介紹

    python進(jìn)階教程之模塊(module)介紹

    這篇文章主要介紹了python進(jìn)階教程之模塊(module)介紹,本文講解了基礎(chǔ)知識(shí)、引用方法、搜索的路徑、模塊包等知識(shí),需要的朋友可以參考下
    2014-08-08
  • Django零基礎(chǔ)入門之自定義標(biāo)簽及模板中的使用

    Django零基礎(chǔ)入門之自定義標(biāo)簽及模板中的使用

    這篇文章主要介紹了Django零基礎(chǔ)入門之自定義標(biāo)簽及模板中的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • python使用建議與技巧分享(一)

    python使用建議與技巧分享(一)

    這篇文章主要介紹了python使用建議與技巧分享,幫助大家更高效的使用python,感興趣的朋友可以了解下
    2020-08-08
  • Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法

    Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-07-07
  • Python中paramiko模塊的基礎(chǔ)操作與排錯(cuò)問(wèn)題

    Python中paramiko模塊的基礎(chǔ)操作與排錯(cuò)問(wèn)題

    python的ssh庫(kù)操作需要引入一個(gè)遠(yuǎn)程控制的模塊——paramiko,可用于對(duì)遠(yuǎn)程服務(wù)器進(jìn)行命令或文件操作,這篇文章主要介紹了Python學(xué)習(xí)之paramiko模塊的基礎(chǔ)操作與排錯(cuò),需要的朋友可以參考下
    2022-09-09

最新評(píng)論