修复ExcelCom加载项失效问题及WPS可调用Com加载项的方法

为了还原一个干净无侵扰的网络世界,本文将不进行大规模地分发,若您觉得此文有用,不妨小范围地分享到真正有需要的人手中

功能概述

修复ExcelCom加载项常见问题,如每次需重新勾选COM加载项或COM加载项被列入禁用清单中不用使用,同时也提供让WPS计用COM加载项的方法

使用场景

因用户在使用COM技术开发的加载项过程中,难免各种意外操作,致使加载项处理非活动状态或失效状态,虽然可以通过界面的方式去解决,但步骤偏多,对普通用户来说,较难以去理解及操作,将其封装成一个exe文件,让用户自行双击运行解决是个不错的解决方案,本篇代码也是为这个功能场景而开发的。

技术原理

其实COM加载项的活动与否、禁用与否,都会在注册表上写上相关信息,只需从注册表层面对用户电脑的注册表项进行修改,即可实现非Excel界面操作的方式实现自动化修复插件。

WPS调用COM加载项原理,也只是在注册表上新增几个条目,让WPS可以通过查找注册表,找到COM加载项所在位置并调用它。

详细代码

using Microsoft.Win32;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 插件修复程序
{
 class Program
 {
 private static string addinsKeyWords = "Excel催化剂";//可以模糊查找注册表里含此关键字的条目
 static void Main(string[] args)
 {
 ExcelRepair();
 Console.WriteLine("修复完成,请按任意键退出!");
 Console.ReadKey();
 }
 private static void ExcelRepair()
 {
 //TODO:检查禁用项
 CheckDisalbledItem();
 //TODO:检查Addin注册表
 CheckRegister();
 //增加WPS可识别VSTO插件的方法,具体需要看真正安装后的注册表路径及项目名称是什么而定。
 LetWPSRunAddins();
 }
 private static void CheckDisalbledItem()
 {
 string keypath = @"SoftwareMicrosoftOffice"; //15.0ExcelResiliencyDisabledItems
 RegistryKey key = Registry.CurrentUser.OpenSubKey(keypath, true);
 FindAndDeleteDisabledItems(key, "DisabledItems", addinsKeyWords);
 }
 public static void CheckRegister()
 {
 RegistryKey key = Registry.CurrentUser;
 RegistryKey addins = key.OpenSubKey(@"SoftwareMicrosoftOfficeExcelAddins", true);
 foreach (var item in addins.GetSubKeyNames())
 {
 if (item.ToUpper().Contains(addinsKeyWords.ToUpper()))
 {
 var addin = addins.OpenSubKey(item, true);
 addin.SetValue("LoadBehavior", "3", RegistryValueKind.DWord);//将启动方式改为3,即Excel打开时立即运行插件
 }
 }
 }
 private static void LetWPSRunAddins()
 {
 RegistryKey key = Registry.CurrentUser;
 RegistryKey addins = key.OpenSubKey(@"SoftwareMicrosoftOfficeExcelAddins", true);
 var wps = key.CreateSubKey(@"SoftwareKingsoftOfficeETAddinsWL");
 wps.SetValue("Excel催化剂工作室.Excel催化剂", "Excel催化剂工作室.Excel催化剂", RegistryValueKind.String);
 wps.SetValue("Excel催化剂", "Excel催化剂", RegistryValueKind.String);
 wps.SetValue("Excel催化剂工作室.Excel催化剂离线版", "Excel催化剂工作室.Excel催化剂离线版", RegistryValueKind.String);
 }
 /// 
 /// 查找指定项指定内容
 /// 
 /// 
 /// 这里是禁用项的名称
 /// 自己插件的名称
 private static void FindAndDeleteDisabledItems(RegistryKey key, string subkeyname, string deleteStr)
 {
 if (key.Name.Contains(subkeyname))
 {
 for (int i = 0; i < key.ValueCount; i++)
 {
 try
 {
 foreach (var item in key.GetValueNames().Where(s => Encoding.Unicode.GetString((byte[])key.GetValue(s)).ToUpper().Contains(deleteStr.ToUpper())))
 {
 key.DeleteValue(item);
 }
 }
 catch (Exception ex)
 {
 continue;
 }
 }
 return;
 }
 if (key.SubKeyCount > 0)
 {
 foreach (var item in key.GetSubKeyNames())
 {
 try
 {
 FindAndDeleteDisabledItems(key.OpenSubKey(item, true), subkeyname, deleteStr);
 }
 catch (Exception ex)
 {
 continue;
 }
 }
 }
 }
 }
}

开源地址为:https://github.com/minren118/ExcelUdfByExcelCuiHuaJi,不妨对您有帮助时帮忙在GtiHub上点个赞。


修复ExcelCom加载项失效问题及WPS可调用Com加载项的方法


登录Github后点击红框给个星星

展开阅读全文

页面更新:2024-04-26

标签:加载   离线   条目   催化剂   注册表   插件   场景   界面   原理   状态   名称   工作室   操作   方式   方法   数码   用户

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top