Tworzenie diagramu ORG w Pythonie

Ten artykuł opisuje, jak utworzyć diagram ORG w Pythonie. Zawiera wymagania systemowe, szczegółowy proces krok po kroku oraz działający kod do tworzenia schematu organizacyjnego w Pythonie. Ponadto umożliwia dostosowanie wyglądu diagramu i eksportowanie go do formatu pliku VSDX lub VSD zgodnie z wymaganiami.

Kroki tworzenia diagramu ORG w Pythonie

  1. Zainstaluj Aspose.Diagram na swoim systemie, aby utworzyć diagram ORG
  2. Zainicjalizuj instancję klasy Diagram, aby załadować podstawowe kształty z przykładowego szablonu
  3. Dodaj wymagane kształty i wstaw połączenia między różnymi węzłami
  4. Ustaw różne właściwości diagramu za pomocą klasy LayoutOptions i wygeneruj wynikowy diagram ORG

Powyższe kroki przedstawiają proces tworzenia generatora diagramu ORG w Pythonie. Najpierw należy skonfigurować środowisko i załadować podstawowe kształty z pliku szablonu. Następnie dodajemy wymagane kształty oraz ich połączenia, a na końcu generujemy i zapisujemy wynikowy diagram.

Kod do tworzenia diagramu ORG w Pythonie

import aspose.diagram
from aspose.diagram import *
path = "C://"
# Load masters from any existing diagram, stencil or template
visioStencil = path + "BasicShapes.vss"
rectangleMaster = "Rectangle"
connectorMaster = "Dynamic connector"
pageNumber = 0
width = 1.0
height = 1.0
pinX = 4.25
pinY = 9.5
# Define values to construct the hierarchy
listPos = ["0", "0:0", "0:1", "0:2", "0:3", "0:4", "0:5", "0:6", "0:0:0", "0:0:1", "0:3:0", "0:3:1", "0:3:2", "0:6:0", "0:6:1"]
# Define a dictionary to map the string name to long shape id
shapeIdMap = {}
# Create a new diagram
diagram = Diagram(visioStencil)
diagram.pages[pageNumber].page_sheet.page_props.page_width.value = 11.0
for orgnode in listPos:
# Add a new rectangle shape
rectangleId = diagram.add_shape(pinX, pinY, width, height, rectangleMaster, pageNumber)
pinX += 1
pinY += 1
# Set the new shape's properties
shape = diagram.pages[pageNumber].shapes.get_shape(rectangleId)
shape.text.value.add(Txt(orgnode))
shape.name = orgnode
shapeIdMap[orgnode] = rectangleId
# Create connections between nodes
for orgName in listPos:
lastColon = orgName.rfind(':')
if lastColon > 0:
parentName = orgName[:lastColon]
shapeId = shapeIdMap[orgName]
parentId = shapeIdMap[parentName]
connector1 = Shape()
connecter1Id = diagram.add_shape(connector1, connectorMaster, pageNumber)
diagram.pages[pageNumber].connect_shapes_via_connector(parentId, manipulation.ConnectionPointPlace.RIGHT,
shapeId, manipulation.ConnectionPointPlace.LEFT, connecter1Id)
# Auto layout CompactTree chart
compactTreeOptions = autolayout.LayoutOptions()
compactTreeOptions.layout_style = autolayout.LayoutStyle.COMPACT_TREE
compactTreeOptions.direction = autolayout.LayoutDirection.DOWN_THEN_RIGHT
compactTreeOptions.enlarge_page = False
diagram.pages[pageNumber].layout(compactTreeOptions)
# Save diagram
diagram.save("ORGchart_out.vsdx", SaveFileFormat.VSDX)

Powyższy fragment kodu pokazuje, jak zaimplementować narzędzie do tworzenia diagramów ORG w Pythonie. Można go dostosować, zmieniając liczbę kształtów, ich układ, kierunek połączeń czy pozycję węzłów. Dodatkowo można modyfikować kształty i ich połączenia, zmieniając identyfikator nadrzędnego węzła i inne właściwości według potrzeb.

Ten artykuł wyjaśnił, jak utworzyć narzędzie do tworzenia schematów organizacyjnych w Pythonie. Jeśli interesuje Cię tworzenie diagramów Visio od podstaw, zapoznaj się z artykułem Tworzenie diagramu Visio w Pythonie.

 Polski