Funkce a vlastnosti
Funkce a vlastnosti
Tato stránka pokrývá každou hlavní funkci aspose-email-foss 26.3 s funkčními příklady Python.
Čtení souborů MSG
Načtěte soubor MSG a přistupujte k jeho základním vlastnostem:
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}")Vytváření souborů MSG
Vytvořte novou zprávu od nuly:
from aspose.email_foss.msg import MapiMessage
msg = MapiMessage.create("Meeting Notes", "Please find the notes attached.")
msg.save("new_message.msg")Nastavte předmět a tělo existující zprávy:
msg.subject = "Updated Subject"
msg.body = "Updated body text"
msg.save("updated.msg")Příjemci
Přidejte příjemce s zobrazovanými jmény a typy:
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")Přílohy
Přidejte binární souborové přílohy:
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")Vložte zprávu MSG jako vnořenou přílohu:
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 vlastnosti
Čtěte a zapisujte MAPI vlastnosti podle ID vlastnosti:
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")Procházejte všechny vlastnosti:
for prop in msg.iter_properties():
print(f"Tag: {prop.property_tag:#010x}")Převod e‑mailů
Převádějte mezi formáty MSG (MAPI) a e‑mail (RFC 5322):
# 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")Operace na nízké úrovni s CFB
Čtěte strukturu kontejneru CFB přímo:
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()Zapisujte dokumenty CFB:
from aspose.email_foss.msg import MsgWriter
data = msg.to_bytes()
with open("output.msg", "wb") as f:
f.write(data)Tipy a osvědčené postupy
- Vždy zavolejte
msg.close()nebo použijte správce kontextu po dokončení čtení k uvolnění souborových handle - Použijte
msg.validation_issueske kontrole problémů s kompatibilitou formátu MSG - Tento
strictparametr vMapiMessage.from_file()řídí toleranci chyb — nastavte naFalsepro shovívavé parsování - Všechna data příloh jsou načtena do paměti během
from_file()— použijteatt.datak přímému přístupu k bajtům;iter_attachments_info()je pohodlný iterátor přes již naplněný seznam příloh - Použijte
to_email_string()pro rychlé náhledy textu bez úplné konstrukce objektu e‑mailu
Běžné problémy
| Problém | Příčina | Oprava |
|---|---|---|
CFBError při načítání | Neplatný soubor CFB/MSG | Ověřte, že soubor je skutečný Outlook MSG |
| Prázdné tělo po načtení | Tělo uloženo pouze v HTML | Zkontrolovat msg.body_html místo msg.body |
| Chybějící příjemci | MSG nemá úložiště příjemců | Příjemci jsou v formátu MSG volitelní; zkontrolujte iter_attachments_info() |
FAQ
Jaké verze formátu MSG jsou podporovány?
Knihovna čte a zapisuje soubory MSG ve formátu CFB v3 a v4, kompatibilní s Microsoft Outlook.
Mohu číst soubory EML?
Ne přímo. Knihovna zpracovává formát MSG. Použijte MapiMessage.from_email_message() k převodu z RFC 5322 EmailMessage objekty.
Je thread‑safety podporována?
Každý MapiMessage a CFBReader instance je nezávislá. Současný přístup k samostatným instancím z různých vláken je bezpečný.
Shrnutí referenčního API
| Třída / Metoda | Popis |
|---|---|
MapiMessage | Vysoce úrovňová reprezentace zprávy MSG |
MapiMessage.from_file() | Načíst soubor MSG |
MapiMessage.create() | Vytvořit novou zprávu MSG |
MapiMessage.save() | Uložit do souboru MSG |
MapiMessage.to_email_message() | Převést na EmailMessage (RFC 5322) |
MapiMessage.from_email_message() | Převést z EmailMessage do MSG |
MapiMessage.add_recipient() | Přidat příjemce |
MapiMessage.add_attachment() | Přidat binární přílohu |
MapiAttachment | Příloha ve zprávě |
MapiRecipient | Příjemce ve zprávě |
MapiProperty | Záznam vlastnosti MAPI |
CFBReader | Nízká úroveň čtečky kontejneru CFB |
CFBWriter | Nízká úroveň zapisovače kontejneru CFB |
MsgReader | Nízká úroveň čtečky struktury MSG |