提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:黄竹雯|2019-03-06 13:53:53.000|阅读 610 次
概述:本文主要介绍如何使用Aspose.Words将HTML转换为PDF、将档转换为MHTML和电子邮件等。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
Aspose.Words无需Microsoft Word也可在任何平台上满足Word文档的一切操作需求。本文将与大家分享如何将word和图像转换为PDF。
【下载Aspose.Words for .NET最新试用版】
要将HTML转换为PDF,只需调用Document.Save方法并指定扩展名为“.PDF”即可。如果要从外部源加载图像和CSS等,可以使用IResourceSavingCallback。下面的代码示例演示将HTML转换为PDF并从外部源加载图像。
// For complete examples and data files, please go to //github.com/aspose-words/Aspose.Words-for-.NET
public class ImageLoadingWithCredentialsHandler : IResourceLoadingCallback
{
public ImageLoadingWithCredentialsHandler()
{
mWebClient = new WebClient();
}
public ResourceLoadingAction ResourceLoading(ResourceLoadingArgs args)
{
if (args.ResourceType == ResourceType.Image)
{
Uri uri = new Uri(args.Uri);
if (uri.Host == "www.aspose.com")
mWebClient.Credentials = new NetworkCredential("User1", "akjdlsfkjs");
else
mWebClient.Credentials = new NetworkCredential("SomeOtherUserID", "wiurlnlvs");
// Download the bytes from the location referenced by the URI.
byte[] imageBytes = mWebClient.DownloadData(args.Uri);
args.SetData(imageBytes);
return ResourceLoadingAction.UserProvided;
}
else
{
return ResourceLoadingAction.Default;
}
}
private WebClient mWebClient;
}
使用Aspose.Words我们可以检查字体资源是否应该以base 64编码嵌入到HTML中。默认情况下,该值为false,字体将写入单独的文件。如果此选项设置为true,则字体将嵌入到Base64编码的文档CSS中。 该属性仅影响HTML格式,不会影响EPUB和MHTML。这是HtmlSaveOptions.ExportFontResources选项的扩展,ExportFontsAsBase64仅在此属性设置为true时才有效。下面的示例演示如何使用Base64编码将字体导出为HTML。
// For complete examples and data files, please go to //github.com/aspose-words/Aspose.Words-for-.NET // The path to the documents directory. string dataDir = RunExamples.GetDataDir_LoadingAndSaving(); string fileName = "Document.doc"; Document doc = new Document(dataDir + fileName); HtmlSaveOptions saveOptions = new HtmlSaveOptions(); saveOptions.ExportFontResources = true; saveOptions.ExportFontsAsBase64 = true; dataDir = dataDir + "ExportFontsAsBase64_out.html"; doc.Save(dataDir, saveOptions);
使用Aspose.Words,我们可以指定一个文件夹,在将文档导出为HTML时,可以保存图像,字体和外部CSS等所有资源。默认值为空字符串。ResourceFolder是指定应写入所有资源的文件夹的最简单方法。我们可以使用FontsFolder等单独的属性将字体保存到指定的文件夹,使用ImagesFolder将图像保存到指定的文件夹。
使用ResourceFolderAlias属性,我们还可以指定用于构造写入HTML文档的所有资源的URI的文件夹的名称,这是指定应如何构造所有资源文件的URI的最简单方法。可以通过ImagesFolderAlias和FontsFolderAliasproperties分别为图像和字体指定相同的信息。 但是,CSS没有单独的属性。 FontsFolder,FontsFolderAlias,ImagesFolder,ImagesFolderAlias和CssStyleSheetFileName属性的行为不会更改。请注意,CssStyleSheetFileName属性用于指定文件夹名称和文件名。
指定相对路径时,FontsFolder和ImagesFolder相对于代码程序集所在的文件夹,ResourceFolder和CssStyleSheetFileName相对于HTML文档所在的输出文件夹。在下面的示例中,ResourceFolder指定此路径相对于输出文件夹的相对路径,其中保存HTML文档,http://example.com/resources 别名用于构造所有资源的URL。
// For complete examples and data files, please go to //github.com/aspose-words/Aspose.Words-for-.NET // The path to the documents directory. string dataDir = RunExamples.GetDataDir_LoadingAndSaving(); string fileName = "Document.doc"; Document doc = new Document(dataDir + fileName); HtmlSaveOptions saveOptions = new HtmlSaveOptions(); saveOptions.CssStyleSheetType = CssStyleSheetType.External; saveOptions.ExportFontResources = true; saveOptions.ResourceFolder = dataDir + @"\Resources"; saveOptions.ResourceFolderAlias = "//example.com/resources"; doc.Save(dataDir + "ExportResourcesUsingHtmlSaveOptions.html", saveOptions);
Aspose.Words可以以MHTML(Web Archive)格式保存任何文档。这使得Aspose.Words和Aspose.Email一起使用可以生成和发送内容丰富的电子邮件。例如,你可以将预定义的DOC,OOXML或RTF文档加载到Aspose.Words中,用数据填充之后另存为MHTML,然后使用Aspose.Email发送电子邮件。 下面的代码示例演示了如何使用Aspose.Email将Aspose.Words中的文档保存为MHTML和电子邮件。
// For complete examples and data files, please go to //github.com/aspose-words/Aspose.Words-for-.NET // The path to the documents directory. string dataDir = RunExamples.GetDataDir_LoadingAndSaving(); // Load the document into Aspose.Words. Document doc = new Document(dataDir + "Test File (docx).docx"); // Save into a memory stream in MHTML format. Stream stream = new MemoryStream(); doc.Save(stream, SaveFormat.Mhtml); // Rewind the stream to the beginning so Aspose.Email can read it. stream.Position = 0; // Create an Aspose.Network MIME email message from the stream. MailMessage message = MailMessage.Load(stream, new MhtmlLoadOptions()); message.From = "your_from@email.com"; message.To = "your_to@email.com"; message.Subject = "Aspose.Words + Aspose.Email MHTML Test Message"; // Send the message using Aspose.Email SmtpClient client = new SmtpClient(); client.Host = "your_smtp.com"; client.Send(message);
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn




在嵌入式软件测试领域,对交叉编译代码进行单元测试是一大挑战。Parasoft C/C++test作为专业的C/C++测试工具,能够与劳特巴赫Trace32调试器深度集成。下面会详细介绍如何在C++test中配置Trace32调试器,实现对PowerPC架构程序的单元测试,涵盖环境设置、项目导入到测试执行的全过程。
本文将为大家介绍如何使用DevExpress WinForms数据网格控件实现摘要文本的格式化,欢迎下载最新版组件体验!
Parasoft C/C++test作为一款功能强大的自动化测试工具,为嵌入式开发提供了全面的测试解决方案。特别是在CCS开发环境中,C++test能够无缝集成,为F2812等DSP项目提供专业的单元测试支持。下面将介绍如何在CCS3环境下配置和使用C++test进行F2812项目的单元测试。
在嵌入式开发中,尤其是基于ARM架构的安全关键领域,单元测试是验证代码在目标硬件上运行时行为正确性的关键环节,对于保障最终产品的可靠性至关重要。下面将介绍如何利用Parasoft C/C++test开展单元测试,包括配置、执行及解决可能遇到的许可证问题,完成从静态检查到动态运行的完整测试闭环。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站