C#通过注册表查看电脑是否安装office或office版本

首先说明64位操作系统和32位操作系统中office的注册表编辑器可能不同。
我的电脑是64位的但是获取到的值一直是null,后来发现我的程序目标运行平台是x86,很明显是使用了32位注册表编辑器的结果。将目标平台改为64位或者AnyCpu,问题即可解决。
如果32位程序想要访问64位系统的注册表,只需要判断是否是64位的操作系统(Environment.Is64BitOperatingSystem ),然后通过注册表打开目录时,传入相应的RegistryView枚举即可。

	public bool panduan()
        {
            bool ifused = istrue;
            RegistryKey rk = Registry.LocalMachine;
			if (Environment.Is64BitOperatingSystem)
   				rk = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry64);
			else
   				rk = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry32);
            
            RegistryKey office2013 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\15.0\\Word\\InstallRoot\\");
            RegistryKey office2010 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\14.0\\Word\\InstallRoot\\");
            //office 2003
            RegistryKey office2003 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\11.0\\Word\\InstallRoot\\");
            //office2007
            RegistryKey office2007 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\12.0\\Word\\InstallRoot\\");
            //office 97
            RegistryKey office97 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\8.0\\Word\\InstallRoot\\");
            //office 2000
            RegistryKey office2000 = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\9.0\\Word\\InstallRoot\\");
            //office xp
            RegistryKey officexp = rk.OpenSubKey(@"SOFTWARE\\Microsoft\\Office\\10.0\\Word\\InstallRoot\\");
            //检查本机是否安装Office2010
            if (office2010 != null)
            {
                string file03 = office2010.GetValue("Path").ToString();
                if (File.Exists(file03 + "Excel.exe"))
                {
                    istrue= true;
                }
            }
            if (officexp != null)
            {
                string filexp = officexp.GetValue("Path").ToString();
                if (File.Exists(filexp + "Excel.exe"))
                {
                    istrue= true;
                }
            }
            if (office2000 != null)
            {
                string file2000 = officexp.GetValue("Path").ToString();
                if (File.Exists(file2000 + "Excel.exe"))
                {
                    istrue= true;
                }
            }
            if (office97 != null)
            {
                string file97 = officexp.GetValue("Path").ToString();
                if (File.Exists(file97 + "Excel.exe"))
                {
                    istrue= true;
                }
            }
            if (office2007 != null)
            {
                string file2007 = officexp.GetValue("Path").ToString();
                if (File.Exists(file2007 + "Excel.exe"))
                {
                    istrue= true;
                }
            }
  
            return istrue;
        }
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页