C#程序未能找到引用的组件VBIDE解决过程

重装系统之后就会因为环境不同而造成原来好好的程序现在编译就出错了:
找不到VBIDE引用
网上说由于电脑没安装Office,所以缺少Interop.VBIDE.dll库,网上下载了一个,注册后也不行。使用CFF Explorer工具查看库信息:
C#程序未能找到引用的组件VBIDE解决过程_第1张图片
发现是32位的版本库,而我电脑是64位系统,于是找一个装Office的电脑把库拷贝一下,查看库所在目录:
C#程序未能找到引用的组件VBIDE解决过程_第2张图片
原来在C:\Windows\assembly目录下,打开目录傻了眼:
C#程序未能找到引用的组件VBIDE解决过程_第3张图片
这怎么查看,于是又百度,原来得用解压软件查看,打开解压软件,输入目录:
C#程序未能找到引用的组件VBIDE解决过程_第4张图片
经过一番周折,终于拷出了Microsoft.Vbe.Interop.dll文件,于是又按照网上说的拷贝到C:\Windows\SysWOW64目录下(因为我的电脑是64位系统,如果是32位请拷到System32目录):
C#程序未能找到引用的组件VBIDE解决过程_第5张图片
然后编写个bat脚本,实现Microsoft.Vbe.Interop的注册(注意路径对应):
C#程序未能找到引用的组件VBIDE解决过程_第6张图片
运行时发现中文乱码:
C#程序未能找到引用的组件VBIDE解决过程_第7张图片
注意文件的编码一定要改为ANSI格式:
C#程序未能找到引用的组件VBIDE解决过程_第8张图片
再运行中文就正常了,虽然显示注册成功了,但打开项目还是找不到引用,使用CFF Explorer查看Microsoft.Vbe.Interop.dll库信息,发现也是32位的:
C#程序未能找到引用的组件VBIDE解决过程_第9张图片
看来和64位系统没关系,网上说的不对啊,从电脑里搜了下Microsoft.Vbe.Interop.dll,发现Microsoft Visual Studio 10.0\Visual Studio Tools for Office\PIA目录里其实是有这个库的:
C#程序未能找到引用的组件VBIDE解决过程_第10张图片
VBE都是32位的库,原来安装VS2010时,只要自定义安装选择了Office工具,就会有这个库:
C#程序未能找到引用的组件VBIDE解决过程_第11张图片
添加这个试试,之后回到项目中,把原来的VBIDE引用移除:
C#程序未能找到引用的组件VBIDE解决过程_第12张图片
重新添加引用:
C#程序未能找到引用的组件VBIDE解决过程_第13张图片
注意这个引用一般会有两个:
C#程序未能找到引用的组件VBIDE解决过程_第14张图片
那么到底使用Office12还是Office14里面的呢,具体得看你引用其他Office库的版本:
C#程序未能找到引用的组件VBIDE解决过程_第15张图片
因为我这个Microsoft.Office.Interop.Excel就是用的Office12,所以这里的Microsoft.Vbe.Interop也选择Office12(个人建议使用Office12,因为如果使用高版本而客户电脑上安装的是低版本,运行程序会报错)。之后再编译项目就OK了。

那么又想到我下载的32位的Interop.VBIDE.dll是否也能使用呢?把它放到项目路径中去,重新添加引用:
C#程序未能找到引用的组件VBIDE解决过程_第16张图片
在浏览中选择放入的Interop.VBIDE.dll文件,添加之后:
C#程序未能找到引用的组件VBIDE解决过程_第17张图片
重新编译也OK。那么又有人说了,原来是VBIDE,你这引用完变成了Interop.VBIDE了,这不一样。没办法,程序员就是有强迫症,下面我们把库文件改个名字:
C#程序未能找到引用的组件VBIDE解决过程_第18张图片
改成了VBIDE.dll,再重新添加一次:
C#程序未能找到引用的组件VBIDE解决过程_第19张图片
OK,这次完全恢复了。

你可能感兴趣的:(环境搭建,C#开发)