2

我正在编写一个使用 Pythongraph-tool库的程序,并且我很幸运地使用了带有graph_tool.draw.radial_tree_layout(g,vertexes[0]). 但是,我的图有几个部分与其余部分截断,并且没有通向我想要的图的任何部分的边。当我绘制图表时,断开的网络被放在中间,在我想要成为中心的顶点之上。因此,我需要一个算法来删除这些没有路径的顶点vertexes[0],或者一个函数将它们放在图上的其他位置,不碍事。

4

1 回答 1

0

我想通了:

(我是从 SQLite 数据库中提取的)

c.execute('SELECT * FROM connections')
ucon = c.fetchall()

lastlevel = ['Philosophy']
nextlevel = []

pcon = []

while lastlevel != []: 
    for i in ucon:
        if i[1] in lastlevel:
            nextlevel.append(i[0])
            pcon.append(i)
    lastlevel = nextlevel
    nextlevel = []

SQLite 数据库中的每一行都是跨越边的起点和终点的元组。这不是很有效,但效果很好!

于 2015-10-13T14:38:08.560 回答