Com desar fitxers adjunts de OneNote amb Python

Com desar fitxers adjunts de OneNote amb Python

Els fitxers OneNote .one poden contenir fitxers adjunts incrustats: qualsevol tipus de fitxer que s’hagi inserit en una pàgina mitjançant Insert → File Attachment a OneNote. Aspose.Note FOSS for Python els exposa a través de la classe AttachedFile, que proporciona el nom de fitxer original i els bytes en cru del fitxer incrustat.


Requisits previs

pip install aspose-note

Pas 1: Carrega el document

from aspose.note import Document

doc = Document("MyNotes.one")

Pas 2: Troba tots els fitxers adjunts

Utilitzeu GetChildNodes(AttachedFile) per recollir recursivament cada adjunt del document, independentment de la pàgina o l’esquema on aparegui:

from aspose.note import Document, AttachedFile

doc = Document("MyNotes.one")
attachments = doc.GetChildNodes(AttachedFile)
print(f"Found {len(attachments)} attachment(s)")

Pas 3: Desa cada adjunt al disc

Accediu af.Bytes per al contingut brut del fitxer i af.FileName per al nom original. Sempre protegeu-vos contra un nom de fitxer None: la biblioteca retorna None quan les metadades del nom de fitxer no es van emmagatzemar al fitxer:

from aspose.note import Document, AttachedFile

doc = Document("MyNotes.one")

for i, af in enumerate(doc.GetChildNodes(AttachedFile), start=1):
    name = af.FileName or f"attachment_{i}.bin"
    with open(name, "wb") as f:
        f.write(af.Bytes)
    print(f"Saved: {name} ({len(af.Bytes):,} bytes)")

Exemple complet

Aquest script extreu tots els fitxers adjunts d’un fitxer .one i els desa en un directori de sortida dedicat:

from pathlib import Path
from aspose.note import Document, AttachedFile

def save_all_attachments(one_path: str, out_dir: str = "attachments") -> None:
    doc = Document(one_path)
    out = Path(out_dir)
    out.mkdir(exist_ok=True)

    attachments = doc.GetChildNodes(AttachedFile)
    if not attachments:
        print("No attachments found.")
        return

    for i, af in enumerate(attachments, start=1):
        name = af.FileName or f"attachment_{i}.bin"
        dest = out / name
        dest.write_bytes(af.Bytes)
        print(f"  [{i}] {name}  ({len(af.Bytes):,} bytes)")

    print(f"\nSaved {len(attachments)} file(s) to '{out_dir}/'")

save_all_attachments("MyNotes.one")

Notes

  • af.Bytes retorna b"" (bytes buits) quan les dades de l’adjunt no s’han pogut analitzar des del fitxer binari. Comproveu len(af.Bytes) > 0 abans de desar si voleu ometre els adjunts buits.
  • af.Tags és una llista d’objectes NoteTag si l’adjunt té aplicades etiquetes OneNote.
  • Aspose.Note FOSS per a Python llegeix fitxers .one però no escriu a .one. No podeu crear ni modificar adjunts.

Vegeu també

 Català