繁体   English   中英

如何以编程方式检查PC上是否存在MS Excel?

[英]How to check, programmatically, if MS Excel exists on a pc?

我有一个需要MS Excel运行的应用程序,否则崩溃。 所以我想检查并警告用户以防用户机器上没有安装Excel。

我该怎么做呢?

Type officeType = Type.GetTypeFromProgID("Excel.Application");
if (officeType == null)
{
     //no Excel installed
}
else
{
     //Excel installed
}

作为快速修复,您可以捕获异常并实现正确的错误处理。 然后你可以在那里通知用户。

const string ASSEMBLY2003 = "Microsoft.Office.Interop.Excel, Version=11.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c";  

static bool IsAssemblyInstalled(string assembly)  
{  
   try 
   {  
       s_assemblyExcel = Assembly.Load(assembly);  
       return true;  
   }   
   catch 
   {  
       return false;  
   }  
} 

这将成功,只为所有版本做到这一点

它也可以这样做

RegistryKey key = Registry.ClassesRoot;
RegistryKey excelKey = key.OpenSubKey("Excel.Application");
bool excelInstalled = excelKey == null ? false : true;

这篇博客文章描述了如何验证Excel是否通过注册表安装 (VB.NET代码,但可以很容易地转换为C#)。 基本上,您将通过HKEY_CLASSES_ROOT\\Excel.Application\\CurVer键进行验证。

这不能回答您的具体问题 ,但是会从另一个方向解决这个问题 ......

它是否真的需要安装MS Excel ,或者您是否需要计算机才能显示Excel文件 例如,如果用户安装了LibreOffice或其他类似的Excel文件兼容应用程序,那么这是可以接受的吗?

我们有一个应用程序可以为用户打开Excel文件和PDF文件。 我们并不关心用户在其计算机上使用的软件来查看这些文件。 这不是我们真正关心的问题。 我们只需要Process.Start(...)文件,让操作系统从那里获取它。

我们将调用包装在Try/Catch块中,并在此调用导致错误时提供用户建议; 建议,例如他们可能没有安装Office(Excel),或者他们缺少PDF查看器。 基本上,我们不是主动尝试识别用户的计算机是否处于完全足够的状态来执行操作,而是假设它是,但是在我们发现它的时候处理这​​种情况。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM