C# 判断access(office)是否安装以及安装的版本

12 篇文章 1 订阅
本文介绍了如何使用C#通过检查注册表信息来检测不同版本的Microsoft Office中Access组件的存在及其版本号,包括Office 97至Office 2016。代码示例详细展示了针对不同版本的查询过程。
摘要由CSDN通过智能技术生成

    因为要使用C#操作Access数据库,安装程序的电脑上面安装的Access数据库版本不能确定,程序需要判断Access版本以便使用正确的连接处理程序。对于office的检测,一般会采用获取注册表的信息来判断当前安装软件的版本。本文整理了如何使用C#判断Access版本,具体代码如下:   

    public static void CheckVersion()
    {
        bool isInstalled = false;
        int version = 0;
        RegistryKey rk = Registry.LocalMachine;
        //office 97
        RegistryKey v97 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\8.0\Access\InstallRoot\");
        //office 2000
        RegistryKey v2000 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\9.0\Access\InstallRoot\");
        //office xp
        RegistryKey vxp = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\10.0\Access\InstallRoot\");
        //office 2003
        RegistryKey v2003 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\11.0\Access\InstallRoot\");
        //查询2007
        RegistryKey v2007 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\12.0\Access\InstallRoot\");
        //查询2010
        RegistryKey v2010 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\14.0\Access\InstallRoot\");
        //查询2013
        RegistryKey v2013 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\15.0\Access\InstallRoot\");
        //查询2016
        RegistryKey v2016 = rk.OpenSubKey(@"SOFTWARE\Microsoft\Office\16.0\Access\InstallRoot\");
        if (v97 != null)
        {
            string file97 = vxp.GetValue("Path").ToString();
            if (File.Exists(file97 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 97;
            }
        }
        if (v2000 != null)
        {
            string file2000 = vxp.GetValue("Path").ToString();
            if (File.Exists(file2000 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2000;
            }
        }
        if (vxp != null)
        {
            string filexp = vxp.GetValue("Path").ToString();
            if (File.Exists(filexp + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2001;
            }
        }
        //检查本机是否安装Office2010
        if (v2010 != null)
        {
            string file03 = v2010.GetValue("Path").ToString();
            if (File.Exists(file03 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2010;
            }
        }
        //检查本机是否安装Office2007
        if (v2007 != null)
        {
            string office07 = v2007.GetValue("Path").ToString();
            if (File.Exists(office07 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2007;
            }
        }
        //检查本机是否安装Office2010
        if (v2010 != null)
        {
            string office10 = v2010.GetValue("Path").ToString();
            if (File.Exists(office10 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2010;
            }
        }
        //检查本机是否安装Office2013
        if (v2013 != null)
        {
            string office13 = v2013.GetValue("Path").ToString();
            if (File.Exists(office13 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2013;
            }
        }
        //检查本机是否安装Office2016       
        if (v2016 != null)
        {
            string office16 = v2016.GetValue("Path").ToString();
            if (File.Exists(office16 + "MSACCESS.EXE"))
            {
                isInstalled = true;
                version = 2016;
            }
        }
        Debug.WriteLine("installed:" + isInstalled.ToString());
        Debug.WriteLine("access version:" + version.ToString());
    }

    本人电脑安装的2007版本,经过上面的代码验证成功。Debug的结果是:   

installed:True
access version:2007

    其他版本的因为没有安装,故没有经过实际测试,不过验证的方法应该大同小异,在真实使用时根据实际情况修改代码即可。

    另外,以上代码可以经过修改,同样可以判断excel,word等是否安装及安装的版本。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值