Why to Convert MHTML to DIF?
MHTML (MIME HTML) is a web page archive format used to save and share web content. It is a combination of HTML code and resources like images, audio, and video. It is used to save webpages for offline viewing and is supported by most web browsers. On the other hand, DIF (Data Interchange Format) is a text-based file format used to store tabular data. It is used to exchange data between different applications and is supported by many spreadsheet programs. Converting MHTML to DIF is beneficial when you need to store web content in a tabular format.
How Aspose.Total Helps for MHTML to DIF Conversion?
Aspose.Total for C++ is a suite of file format automation libraries that helps developers to work with various file formats. It provides APIs to export MHTML to XLSX and convert XLSX to DIF. The process of converting MHTML to DIF in C++ via Aspose.Total for C++ is a simple two step process. In the first step, you can export MHTML to XLSX by using Aspose.PDF for C++. After that, by using Aspose.Cells for C++ Spreadsheet Programming API, you can convert XLSX to DIF. Aspose.Total for C++ provides a comprehensive set of features to work with MHTML and DIF files. It also provides a wide range of features to manipulate and convert other file formats.
C++ API to Convert MHTML to DIF
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 .
// supports PDF, CGM, EPUB, TeX, PCL, PS, SVG, XPS, MD, MHTML, XML, and XSLFO file format | |
// Load the PDF. | |
auto doc = MakeObject<Document>(u"sourceFile.pdf"); | |
// Save in XLSX format. | |
doc->Save(u"XlsxOutput.xlsx", SaveFormat::Xlsx); | |
// Load the XLSX. | |
intrusive_ptr<Aspose::Cells::IWorkbook> wkb = Factory::CreateIWorkbook(u"XlsxOutput.xlsx"); | |
// supports CSV, XLSB, XLSM, XLT, XLTX, XLTM, XLAM, TSV, TXT, ODS, DIF, MD, SXC, and FODS file format | |
// Save in CSV format. | |
wkb->Save(u"convertedFile.csv", SaveFormat_Csv); |
Get or Set MHTML File Information via C++
Aspose.PDF for C++ also allows you to get information about your MHTML document and lets you take informed decisions before your conversion process. In order to get file specific information of a MHTML file, you first need to call the get_Info() method of Document class. Once the DocumentInfo object is retrieved, you can get the values of the individual properties. Furthermore, you can also set the properties by using respective methods of DocumentInfo class.
// supports PDF, CGM, EPUB, TeX, PCL, PS, SVG, XPS, MD, MHTML, XML, and XSLFO file format | |
// load the PDF. | |
auto doc = MakeObject<Document>(L"DocumentInfo.pdf"); | |
// get document informtion object | |
info = doc->get_Info(); | |
// set author | |
info->set_Author(L"John Doe"); | |
// set subject | |
info->set_Subject(L"Working with Document Info"); | |
// set title | |
info->set_Title(L"Get/set document's info"); | |
// get and print document information | |
Console::WriteLine(L"Author: {0}", info->get_Author()); | |
Console::WriteLine(L"Subject: {0}", info->get_Subject()); | |
Console::WriteLine(L"Title: {0}", info->get_Title()); |
Save DIF File Format to Stream via C++
Aspose.Cells for C++ allows saving DIF file format to stream. To save files to a stream, create a MemoryStream or FileStream object and save the file to that stream object by calling the IWorkbook object’s Save method. Specify the desired file format using the SaveFormat enumeration when calling the Save method.
// supports CSV, XLSB, XLSM, XLT, XLTX, XLTM, XLAM, TSV, TXT, ODS, DIF, MD, SXC, and FODS file format | |
// load sample CSV file | |
intrusive_ptr<IWorkbook> workbook = Factory::CreateIWorkbook("sampleExcelFile.csv"); | |
// create FileStream object | |
intrusive_ptr<FileStream> stream = new FileStream("outputSavingFiletoStream.csv"), FileMode_CreateNew); | |
// save the Workbook to Stream | |
workbook->Save(stream, SaveFormat_Csv); | |
// working with stream.. |