Python pyvis图形要么重叠,要么不显示标签

Python pyvis图形要么重叠,要么不显示标签,python,pyvis,Python,Pyvis,我正在做一个项目,在这个项目中,我从一个python repo中绘制了一个图形,我的代码非常长,而不是重要的部分。但在这里,如果有人想要报道: import ast from radon.visitors import ComplexityVisitor import re import os from pyvis.network import Network class Vert: def __init__(self, name, id, size ,edges):

我正在做一个项目,在这个项目中,我从一个python repo中绘制了一个图形,我的代码非常长,而不是重要的部分。但在这里,如果有人想要报道:

import ast
from radon.visitors import ComplexityVisitor
import re
import os
from pyvis.network import Network


class Vert:
    def __init__(self, name, id, size ,edges):
        self.name = name
        self.size = size
        self.edges = edges
        self.id = id
        
from pathlib import Path

rootDir = "/home/ask/Git/Zeeguu-API/"
directories = set()
# this is horrible
for file in Path(rootDir).rglob("*.py"):
    localDirs = str(file).split('/')
    directories.add(localDirs[-2])


def extract_importandClass_from_line(unline):

    x = re.search("^import (\S+)", unline) 
    x = re.search("^from (\S+)", unline) 
    return x.group(1)#, c.group(1).split('(')[0]
def extractClass(inline):
    c = re.search("^class (\S+)", inline) 
    return c.group(1).split('(')[0]


def importsAndClass(file):
    lines = [line for line in open(file)]
    classes = []
    all_imports = []
    for line in lines:
        try:
            imports = extract_importandClass_from_line(line)
            importEnd = imports.rsplit('.',1)[-1]
            importsFormatted = imports.replace('.', '/')
            if (importEnd not in directories):
                all_imports.append(importsFormatted)
        except:
            try:
                class1 = extractClass(line)
                classes.append(class1)
            except:
                continue  
  
    return all_imports, classes
net = Network(directed=True, height="1500px", width="100%")
nodes = {}
nodeNames = set()
counter = 0
for file in Path(rootDir).rglob("*.py"):
    # Opening file, and looking at contents
    f = open(file, "r")
    s = f.read()
    # analyzing complexity
    filename = str(file).replace(rootDir, "")
    analyzer = ComplexityVisitor.from_code(s)
    
    # getting the file name 
    splitFile = os.path.splitext(file.name)
    #getting imports    
    imports, classes = importsAndClass(file)

    nodeNames.add(str(filename))
    v = Vert(str(filename), counter,analyzer.total_complexity, imports)
    #creating vertex
    nodes[v.name] = v
    counter = counter + 1 
    net.add_node(v.id, label=v.name, size=v.size*2)

print("_________________________________")
for k, v in nodes.items():
    
    for i in v.edges:
        withPY = i + ".py"
        print(withPY)
        try:
            to = nodes[withPY].id 
            net.add_edge(v.id, to)
        except:
            print("could not add edge to:" + str(i))    
        


net.show("network.html")
现在,当我画我的图表时,它看起来像是,东西超级聚在一起。 所以我想用一些方法来避免重叠。经过一点研究,我发现我应该加上这一行:

net.barnes_hut(overlap=1)
我知道。这会导致,看起来更好,但现在突然,节点上的所有标签都消失了

为什么我的标签不见了?如何获得非重叠和标签? 编辑:

我现在尝试了这个选项:

net.force_atlas_2based(overlap= 1)
这确实是我想要的。现在唯一的问题是节点有时会相互碰撞,并开始无法控制地摆动