46 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| =======
 | |
| Sampson
 | |
| =======
 | |
| 
 | |
| Sampson's monastery data.
 | |
| 
 | |
| Shows how to read data from a zip file and plot multiple frames.
 | |
| 
 | |
| The data file can be found at:
 | |
| 
 | |
| - https://github.com/networkx/networkx/blob/master/examples/drawing/sampson_data.zip
 | |
| """
 | |
| 
 | |
| import zipfile
 | |
| from io import BytesIO as StringIO
 | |
| 
 | |
| import matplotlib.pyplot as plt
 | |
| import networkx as nx
 | |
| 
 | |
| with zipfile.ZipFile("sampson_data.zip") as zf:
 | |
|     e1 = StringIO(zf.read("samplike1.txt"))
 | |
|     e2 = StringIO(zf.read("samplike2.txt"))
 | |
|     e3 = StringIO(zf.read("samplike3.txt"))
 | |
| 
 | |
| G1 = nx.read_edgelist(e1, delimiter="\t")
 | |
| G2 = nx.read_edgelist(e2, delimiter="\t")
 | |
| G3 = nx.read_edgelist(e3, delimiter="\t")
 | |
| pos = nx.spring_layout(G3, iterations=100)
 | |
| plt.clf()
 | |
| 
 | |
| plt.subplot(221)
 | |
| plt.title("samplike1")
 | |
| nx.draw(G1, pos, node_size=50, with_labels=False)
 | |
| plt.subplot(222)
 | |
| plt.title("samplike2")
 | |
| nx.draw(G2, pos, node_size=50, with_labels=False)
 | |
| plt.subplot(223)
 | |
| plt.title("samplike3")
 | |
| nx.draw(G3, pos, node_size=50, with_labels=False)
 | |
| plt.subplot(224)
 | |
| plt.title("samplike1,2,3")
 | |
| nx.draw(G3, pos, edgelist=list(G3.edges()), node_size=50, with_labels=False)
 | |
| nx.draw_networkx_edges(G1, pos, alpha=0.25)
 | |
| nx.draw_networkx_edges(G2, pos, alpha=0.25)
 | |
| plt.show()
 |