Funktionen und Merkmale

Funktionen und Merkmale

Diese Seite behandelt jedes Hauptmerkmal von aspose-email-foss 26.3 mit funktionierenden Python-Beispielen.


Lesen von MSG-Dateien

Laden Sie eine MSG-Datei und greifen Sie auf ihre Kerneigenschaften zu:

from aspose.email_foss.msg import MapiMessage

msg = MapiMessage.from_file("message.msg")

print(f"Subject: {msg.subject}")
print(f"Body: {msg.body}")
print(f"HTML Body: {msg.body_html}")
print(f"Message Class: {msg.message_class}")

Erstellen von MSG-Dateien

Erstellen Sie eine neue Nachricht von Grund auf:

from aspose.email_foss.msg import MapiMessage

msg = MapiMessage.create("Meeting Notes", "Please find the notes attached.")
msg.save("new_message.msg")

Betreff und Text in einer bestehenden Nachricht festlegen:

msg.subject = "Updated Subject"
msg.body = "Updated body text"
msg.save("updated.msg")

Empfänger

Empfänger mit Anzeigenamen und Typen hinzufügen:

from aspose.email_foss.msg import MapiMessage, RECIPIENT_TYPE_CC

msg = MapiMessage.create("Hello", "Message body")
msg.add_recipient("alice@example.com", display_name="Alice Smith")
msg.add_recipient("bob@example.com", display_name="Bob Jones", recipient_type=RECIPIENT_TYPE_CC)
msg.save("with_recipients.msg")

Anhänge

Binäre Dateianhänge hinzufügen:

with open("report.pdf", "rb") as f:
    data = f.read()

msg.add_attachment("report.pdf", data, mime_type="application/pdf")
msg.save("with_attachment.msg")

Betten Sie eine MSG-Nachricht als verschachtelten Anhang ein:

inner = MapiMessage.create("Inner Subject", "Inner body")
msg.add_embedded_message_attachment(inner, filename="embedded.msg", mime_type="application/vnd.ms-outlook")
msg.save("with_embedded.msg")

MAPI-Eigenschaften

MAPI-Eigenschaften nach Property-ID lesen und schreiben:

from aspose.email_foss.msg import PropertyId

# Read a property
subject = msg.get_property(PropertyId.SUBJECT)

# Set a property
msg.set_property(PropertyId.SUBJECT, "New Subject")

Alle Eigenschaften durchlaufen:

for prop in msg.iter_properties():
    print(f"Tag: {prop.property_tag:#010x}")

E-Mail-Konvertierung

Konvertieren Sie zwischen MSG (MAPI)- und E-Mail- (RFC 5322)-Formaten:

# MSG to email string
email_str = msg.to_email_string()
print(email_str[:500])

# MSG to EmailMessage object
email_msg = msg.to_email_message()

# EmailMessage back to MapiMessage
msg2 = MapiMessage.from_email_message(email_msg)
msg2.save("roundtrip.msg")

Low-Level CFB-Operationen

Lesen Sie die CFB-Containerstruktur direkt:

from aspose.email_foss.cfb import CFBReader

reader = CFBReader.from_file("message.msg")
print(f"File size: {reader.file_size} bytes")
print(f"Sectors: {reader.fat_sector_count}")
print(f"Entries: {reader.directory_entry_count}")

for entry in reader.iter_storages():
    print(f"Storage: {entry}")

for entry in reader.iter_streams():
    print(f"Stream: {entry}")

reader.close()

Schreiben Sie CFB-Dokumente:

from aspose.email_foss.msg import MsgWriter

data = msg.to_bytes()
with open("output.msg", "wb") as f:
    f.write(data)

Tipps und bewährte Verfahren

  • Rufen Sie immer auf msg.close() oder verwenden Sie einen Kontextmanager, wenn Sie mit dem Lesen fertig sind, um Dateihandles freizugeben
  • Verwenden Sie msg.validation_issues um nach MSG-Formatkonformitätsproblemen zu prüfen
  • Der strict Parameter in MapiMessage.from_file() steuert die Fehlertoleranz — setzen Sie auf False für nachgiebiges Parsen
  • Alle Anhangsdaten werden während from_file() — verwenden att.data um direkt auf Bytes zuzugreifen; iter_attachments_info() ist ein praktischer Iterator über die bereits befüllte Anhangsliste
  • Verwenden to_email_string() für schnelle Textvorschauen ohne vollständige Erstellung des E‑Mail‑Objekts

Häufige Probleme

ProblemUrsacheBehebung
CFBError beim LadenKeine gültige CFB/MSG-DateiÜberprüfen Sie, ob die Datei eine echte Outlook MSG ist
Leerer Body nach dem LadenBody nur in HTML gespeichertPrüfen msg.body_html statt msg.body
Empfänger fehlenMSG hat keine Empfänger‑SpeicherEmpfänger sind im MSG-Format optional; prüfen iter_attachments_info()

FAQ

Welche MSG-Formatversionen werden unterstützt?

Die Bibliothek liest und schreibt MSG-Dateien im CFB v3- und v4-Format, das mit Microsoft Outlook kompatibel ist.

Kann ich EML-Dateien lesen?

Nicht direkt. Die Bibliothek verarbeitet das MSG-Format. Verwenden Sie MapiMessage.from_email_message() um von RFC 5322 zu konvertieren EmailMessage Objekte.

Wird Thread‑Sicherheit unterstützt?

Jeder MapiMessage und CFBReader Instanz ist unabhängig. Gleichzeitiger Zugriff auf separate Instanzen von verschiedenen Threads ist sicher.


API-Referenzübersicht

Klasse / MethodeBeschreibung
MapiMessageHigh-Level MSG-Nachrichtenrepräsentation
MapiMessage.from_file()Lade eine MSG-Datei
MapiMessage.create()Erstelle eine neue MSG-Nachricht
MapiMessage.save()Speichere in MSG-Datei
MapiMessage.to_email_message()Konvertiere zu EmailMessage (RFC 5322)
MapiMessage.from_email_message()Konvertiere von EmailMessage zu MSG
MapiMessage.add_recipient()Empfänger hinzufügen
MapiMessage.add_attachment()Binären Anhang hinzufügen
MapiAttachmentAnhang in einer Nachricht
MapiRecipientEmpfänger in einer Nachricht
MapiPropertyMAPI‑Eigenschaftseintrag
CFBReaderLow‑Level CFB‑Containerleser
CFBWriterLow‑Level CFB‑Containerwriter
MsgReaderLow‑Level MSG‑Strukturleser
 Deutsch