ASP.NET使用WPS WORD转PDF
开发环境:
Windows10 64位+ WPS 2019企业版 +Visual Studio 2019
这是最近又接触到了word和excel转pdf的问题,所以跑回来更新了一下这文。个人感觉在.NET里还是
wps比较友好一些。虽然可能大家都在用npoi,我自己还是喜欢wps。
开发步骤 :
1.直接官网下载wps企业版,安装好后自己网上找个激活码就行,一定得激活或者你有破解版也行,不然还是调用不起来
2.代码引用微软的office组件就行,wps的本质其实也是基于office。
下面直接上代码(代码我是直接从另一个大佬的论坛搬过来的,添加了一些我自己的理解):
// An highlighted block
public class WordToPdfHelper : IDisposable
{
public static readonly log4net.ILog log =
log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
dynamic wps;
public WordToPdfHelper()
{
//创建wps实例,需提前安装wps
Type type = Type.GetTypeFromProgID("KWps.Application");
//如果CreateInstance()报错出现检索 COM 类工厂中 CLSID 为{} 的组件时失败,有几种情况 我在下面会解释
wps = Activator.CreateInstance(type);
}
/// <summary>
/// Word转PDF
/// </summary>
/// <param name="wordPath">Word文件路径</param>
/// <param name="pdfPath">Pdf文件路径</param>
/// <returns></returns>
public bool ToPdf(string wordPath, string pdfPath=null)
{
try
{
if (wordPath == null)
{
throw new ArgumentNullException("wpsFilename");
}
if (pdfPath == null)
{
pdfPath = Path.ChangeExtension(wordPath, "pdf");
}
//用wps 打开word不显示界面
dynamic doc = wps.Documents.Open(wordPath, Visible: false);
//doc 转pdf
doc.ExportAsFixedFormat(pdfPath, Microsoft.Office.Interop.Word.WdExportFormat.wdExportFormatPDF);
//设置隐藏菜单栏和工具栏
//wps.setViewerPreferences(PdfWriter.HideMenubar | PdfWriter.HideToolbar);
doc.Close();
Dispose(); //用完了记得释放进程
}
catch (Exception ex)
{
Dispose();
return false;
}
return true;
}
public void Dispose()
{
if (wps != null) { wps.Quit(); }
}
}
**代码很简单,过程我就只遇到下面这问题,如果有朋友有疑问也可以留言,我看到会帮你解答
Type type = Type.GetTypeFromProgID(“KWps.Application”);
这句如果没有安装WPS是取不到type 的会出现NULL。
Activator.CreateInstance(type);
这里花费了我最多时间。第一次遇到COM引用出错:
检索 COM 类工厂中 CLSID 为 {000209FF-0000-4B30-A977-D214852036FF} 的组件失败,原因是出现以下错误: 80070005 拒绝访问。 (异常来自 HRESULT:0x80070005 (E_ACCESSDENIED))。
遇到这个错误需要把IIS的线程池里的应用程序池标识改为LocalSystem
这样就可以顺利运行啦