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_issuesum nach MSG-Formatkonformitätsproblemen zu prüfen - Der
strictParameter inMapiMessage.from_file()steuert die Fehlertoleranz — setzen Sie aufFalsefür nachgiebiges Parsen - Alle Anhangsdaten werden während
from_file()— verwendenatt.dataum 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
| Problem | Ursache | Behebung |
|---|---|---|
CFBError beim Laden | Keine gültige CFB/MSG-Datei | Überprüfen Sie, ob die Datei eine echte Outlook MSG ist |
| Leerer Body nach dem Laden | Body nur in HTML gespeichert | Prüfen msg.body_html statt msg.body |
| Empfänger fehlen | MSG hat keine Empfänger‑Speicher | Empfä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 / Methode | Beschreibung |
|---|---|
MapiMessage | High-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 |
MapiAttachment | Anhang in einer Nachricht |
MapiRecipient | Empfänger in einer Nachricht |
MapiProperty | MAPI‑Eigenschaftseintrag |
CFBReader | Low‑Level CFB‑Containerleser |
CFBWriter | Low‑Level CFB‑Containerwriter |
MsgReader | Low‑Level MSG‑Strukturleser |