0

我正在将graphviz与python一起使用。我尝试为能量流程图建模。所有商品(技术)都在矩形节点中。产生的所有燃料都是椭圆形的。我想得到一个图表,它可以让我更好地对齐,其中第一列应该是矩形,最后一列也应该是矩形。并且垂直线应该是

矩形 -> 椭圆 -> 矩形 -> 椭圆 -> 矩形 -> 椭圆 -> 矩形 -> 椭圆 -> 矩形(等等)

我怎样才能做到这一点?我检查了文档,但找不到...

谢谢

#!/usr/bin/env python

import pygraphviz as pgv

A=pgv.AGraph(directed=True,strict=False,rankdir='LR')


#@@ 1 COPY ALL TECHNO SET

A.node_attr['shape']='rectangle' #all techno are rectangle 

A.add_node("E01")
A.add_node("E21")
A.add_node("E31")
A.add_node("E51")
A.add_node("E70")
A.add_node("IMPDSL1")
A.add_node("IMPGSL1")
A.add_node("IMPHCO1")
A.add_node("IMPOIL1")
A.add_node("IMPURN1")
A.add_node("RHE")
A.add_node("RHO")
A.add_node("RL1")
A.add_node("SRE")
A.add_node("TXD")
A.add_node("TXE")
A.add_node("TXG")
A.add_node("RIV")
A.add_node("RHu")
A.add_node("RLu")
A.add_node("TXu")

#@@ 2 COPY ALL FUEL SET

A.node_attr['shape']='ellipse' 

A.add_node("DSL")
A.add_node("ELC")
A.add_node("GSL")
A.add_node("HCO")
A.add_node("HYD")
A.add_node("OIL")
A.add_node("DSL")
A.add_node("OIL")
A.add_node("URN")
A.add_node("RH")
A.add_node("RL")
A.add_node("TX")



#@@ 3 COPY ALL OUTPUTACTIVITY

A.add_edge("E01" , "ELC")
A.add_edge("E21" , "ELC")
A.add_edge("E31" , "ELC")
A.add_edge("E51" , "ELC")
A.add_edge("E70" , "ELC")
A.add_edge("IMPDSL1" , "DSL")
A.add_edge("IMPGSL1" , "GSL")
A.add_edge("IMPHCO1" , "HCO")
A.add_edge("IMPOIL1" , "OIL")
A.add_edge("IMPURN1" , "URN")
A.add_edge("RHE" , "RH")
A.add_edge("RHO" , "RH")
A.add_edge("RL1" , "RL")
A.add_edge("SRE" , "DSL")
A.add_edge("SRE" , "GSL")
A.add_edge("TXD" , "TX")
A.add_edge("TXE" , "TX")
A.add_edge("TXG" , "TX")
A.add_edge("RIV" , "HYD")
A.add_edge("RHu" , "RH")
A.add_edge("RLu" , "RL")
A.add_edge("TXu" , "TX")


#@@ 3 COPY ALL INPUTACTIVITY

A.add_edge("DSL", "E70")
A.add_edge("DSL", "RHO")
A.add_edge("DSL", "TXD")
A.add_edge("ELC", "E51")
A.add_edge("ELC", "RHE")
A.add_edge("ELC", "RL1")
A.add_edge("ELC", "TXE")
A.add_edge("GSL", "TXG")
A.add_edge("HCO", "E01")
A.add_edge("HYD", "E31")
A.add_edge("OIL", "SRE")
A.add_edge("URN", "E21")

# adjust a graph parameter
A.graph_attr['epsilon']='0.001'


print A.string() 
A.layout('dot') # layout with dot
A.draw('foo.png') # write to file

在此处输入图像描述

4

1 回答 1

1

您好,我发现一个与命令完美配合的

B=A.add_subgraph(["IMPOIL1","IMPDSL1","RIV", "IMPURN1", "IMPHCO1", "IMPGSL1"])

B.graph_attr['rank']='same'

等等

希望它可以帮助将来的人。

谢谢

于 2014-06-18T23:06:21.093 回答