Kako pretraživati DOM OneNote dokumenta u Python

Kako pretraživati DOM OneNote dokumenta u Python

Aspose.Note FOSS for Python represents a OneNote section file as a tree of typed Python objects. Understanding how to traverse this tree efficiently is the foundation for all content extraction tasks. This guide covers all three traversal approaches: GetChildNodes, директна итерација, и DocumentVisitor.


Model objekta dokumenta

OneNote DOM je striktno stablo:

Document
  ├── Page
  │     ├── Title
  │     │     ├── TitleText (RichText)
  │     │     ├── TitleDate (RichText)
  │     │     └── TitleTime (RichText)
  │     └── Outline
  │           └── OutlineElement
  │                 ├── RichText
  │                 ├── Image
  │                 ├── AttachedFile
  │                 └── Table
  │                       └── TableRow
  │                             └── TableCell
  │                                   └── RichText / Image
  └── Page  (next page ...)

Svaki čvor nasleđuje od Node. Čvorovi koji imaju decu nasleđuju od CompositeNode.


Metod 1: GetChildNodes (rekurzivno, filtrirano po tipu)

CompositeNode.GetChildNodes(Type) izvršava rekurzivno depth‑first pretraživanje celog podstabla i vraća ravnu listu svih čvorova koji odgovaraju datom tipu. Ovo je najpogodniji pristup za izdvajanje sadržaja:

from aspose.note import Document, RichText, Image, Table, AttachedFile

doc = Document("MyNotes.one")

##All RichText nodes anywhere in the document
texts = doc.GetChildNodes(RichText)
print(f"RichText nodes: {len(texts)}")

##All images
images = doc.GetChildNodes(Image)
print(f"Image nodes: {len(images)}")

##All tables
tables = doc.GetChildNodes(Table)
print(f"Table nodes: {len(tables)}")

##All attachments
attachments = doc.GetChildNodes(AttachedFile)
print(f"AttachedFile nodes: {len(attachments)}")

Ograničite pretragu na jednu stranicu pozivanjem GetChildNodes na Page umesto Document:

from aspose.note import Document, Page, RichText

doc = Document("MyNotes.one")
for page in doc.GetChildNodes(Page):
    page_texts = page.GetChildNodes(RichText)
    print(f"  Page has {len(page_texts)} text nodes")

Metod 2: Direktna iteracija dece

for child in node iterira neposredan deca od a CompositeNode. Koristite ovo kada vam je potreban jedan određeni nivo hijerarhije:

from aspose.note import Document

doc = Document("MyNotes.one")

##Direct children of Document are Pages
for page in doc:
    title = (
        page.Title.TitleText.Text
        if page.Title and page.Title.TitleText
        else "(untitled)"
    )
    print(f"Page: {title}")
    # Direct children of Page are Outlines (and optionally Title)
    for child in page:
        print(f"  {type(child).__name__}")

Metod 3: DocumentVisitor

DocumentVisitor obezbeđuje obrazac posetioca za strukturirano prelaženje. Prepišite samo VisitXxxStart/End metode koje su vam potrebne. Posetilac se pokreće pozivanjem doc.Accept(visitor):

from aspose.note import (
    Document, DocumentVisitor, Page, Title,
    Outline, OutlineElement, RichText, Image,
)

class StructurePrinter(DocumentVisitor):
    def __init__(self):
        self._depth = 0

    def _indent(self):
        return "  " * self._depth

    def VisitPageStart(self, page: Page) -> None:
        t = page.Title.TitleText.Text if page.Title and page.Title.TitleText else "(untitled)"
        print(f"{self._indent()}Page: {t!r}")
        self._depth += 1

    def VisitPageEnd(self, page: Page) -> None:
        self._depth -= 1

    def VisitOutlineStart(self, outline) -> None:
        self._depth += 1

    def VisitOutlineEnd(self, outline) -> None:
        self._depth -= 1

    def VisitRichTextStart(self, rt: RichText) -> None:
        if rt.Text.strip():
            print(f"{self._indent()}Text: {rt.Text.strip()!r}")

    def VisitImageStart(self, img: Image) -> None:
        print(f"{self._indent()}Image: {img.FileName!r} ({img.Width}x{img.Height}pts)")

doc = Document("MyNotes.one")
doc.Accept(StructurePrinter())

Dostupne metode posetioca

Par metodaTip čvora
VisitDocumentStart/EndDocument
VisitPageStart/EndPage
VisitTitleStart/EndTitle
VisitOutlineStart/EndOutline
VisitOutlineElementStart/EndOutlineElement
VisitRichTextStart/EndRichText
VisitImageStart/EndImage

Navigacija prema gore u stablu

Svaki čvor izlaže ParentNode i Document svojstvo za navigaciju prema gore:

from aspose.note import Document, RichText

doc = Document("MyNotes.one")
for rt in doc.GetChildNodes(RichText):
    parent = rt.ParentNode   # OutlineElement, TableCell, Title, etc.
    root = rt.Document       # always the Document root
    print(f"  '{rt.Text.strip()!r}' parent={type(parent).__name__}")
    break

Metode upravljanja podređenim čvorovima

CompositeNode takođe izlaže upravljanje decom u memoriji (korisno za programsku izgradnju dokumenta, iako povratno pisanje u .one nije podržano):

MetodOpis
node.FirstChildPrvo direktno dete ili None
node.LastChildPoslednje direktno dete ili None
node.AppendChildLast(child)Dodaj dete na kraj
node.AppendChildFirst(child)Dodaj dete na početak
node.InsertChild(index, child)Umetni na poziciju
node.RemoveChild(child)Ukloni dete

Brojanje čvorova pomoću posetioca

from aspose.note import Document, DocumentVisitor, Page, RichText, Image

class Counter(DocumentVisitor):
    def __init__(self):
        self.pages = self.texts = self.images = 0

    def VisitPageStart(self, page: Page) -> None:
        self.pages += 1

    def VisitRichTextStart(self, rt: RichText) -> None:
        self.texts += 1

    def VisitImageStart(self, img: Image) -> None:
        self.images += 1

doc = Document("MyNotes.one")
c = Counter()
doc.Accept(c)
print(f"Pages={c.pages}  RichText={c.texts}  Images={c.images}")

Odabir prave metode obilaska

ScenarioNajbolji pristup
Pronađi sve čvorove jednog tipa (npr. sve RichText)GetChildNodes(RichText)
Iteriraj samo direktna decafor child in node
Prođite kroz stablo uz kontekst (dubina, stanje roditelja)DocumentVisitor
Navigirajte od sadržaja do roditelja ili korenanode.ParentNode / node.Document

Povezani resursi:

 Српски