Why to Convert
If you are a C++ developer, you may need to add email conversion features inside your applications. Email conversion is a process of changing the format of an email message from one type to another. This is useful when you need to share emails with people who use different email clients or when you need to save emails in a different format.
How Aspose.Total Helps for EMLX to DOCX Conversion
Aspose.Total for C++ is a suite of APIs that provides a comprehensive set of features for developing applications in C++. It includes APIs for manipulating emails, documents, images, and other file formats. Using Aspose.Email for C++, you can convert EMLX file format to HTML. After that, by using Aspose.Words for C++ API, you can export HTML to DOCX. Both APIs come under Aspose.Total for C++ package. This makes it easy to convert EMLX to DOCX in C++ applications.
Aspose.Email for C++ is a powerful API that enables you to manipulate emails in various formats. It provides features for reading, writing, and converting emails from one format to another. It supports a wide range of email formats such as EML, EMLX, MSG, MHT, and more. It also provides features for managing email attachments, adding headers and footers, and more.
Aspose.Words for C++ is a powerful API that enables you to manipulate documents in various formats. It provides features for creating, editing, and converting documents from one format to another. It supports a wide range of document formats such as DOC, DOCX, ODT, HTML, and more. It also provides features for managing document elements, adding headers and footers, and more.
By using Aspose.Total for C++, you can easily convert EMLX to DOCX in C++ applications. It provides a comprehensive set of features for manipulating emails and documents in various formats. It also makes it easy to add email conversion features inside your applications.
C++ API to Convert EMLX to DOCX
- Open EMLX file using MailMessage class reference
- Convert EMLX to HTML by using Save member function
- Load HTML by using Document class
- Save the document to DOCX format using Save method and set Docx as SaveFormat
Get Started with C++ File Format APIs
Install from command line as nuget install Aspose.Total.Cpp
or via Package Manager Console of Visual Studio with Install-Package Aspose.Total.Cpp
.
Alternatively, get the offline MSI installer or DLLs in a ZIP file from downloads .
// load the EMLX file to be converted
System::SharedPtr<MailMessage> msg = MailMessage::Load(u"sourceFile.emlx");
// save EMLX as a HTML
msg->Save(u"HtmlOutput.html", SaveOptions::get_DefaultHtml());
// load HTML with an instance of Document
System::SharedPtr<Document> doc = System::MakeObject<Document>(u"HtmlOutput.html");
// call save method while passing Docx as save format
doc->Save(u"convertedFile.Docx");
Parse EMLX File via C++
Not only you can convert your EMLX to DOCX, but you can read, manipulate, and parse EMLX document. You can get subject, address, body, recipients information of the email by using MapiMessage class of Aspose.Email for C++ API. For example, you can check for a specific sender email for the conversion by using get_SenderEmailAddress() property.
// create an instance of MapiMessage from file
System::SharedPtr<MapiMessage> msg = MapiMessage::FromFile(dataDir + L"message.emlx");
// get subject
System::Console::WriteLine(System::String(L"Subject:") + msg->get_Subject());
// get from address
System::Console::WriteLine(System::String(L"From:") + msg->get_SenderEmailAddress());
// get body
System::Console::WriteLine(System::String(L"Body") + msg->get_Body());
// get recipients information
System::Console::WriteLine(System::String(L"Recipient: ") + msg->get_Recipients());
C++ API to Restrict DOCX File Format Editing
You can also add document protection features in your app while exporting the document from EMLX to DOCX. Adding protection to your document is a simple process, as all you need to do is apply the protection method to your document. You can set protection type to ReadOnly to restrict the user to edit the document.
// create a new document and protect it with a password.
auto doc = System::MakeObject<Document>();
// apply Document Protection.
doc->Protect(ProtectionType::ReadOnly, u"password");
// save the document.
doc->Save(u"DocumentProtection.PasswordProtection.Docx");