C# 创建vba用的类库

目录

  • [一. 需求](#一. 需求)
  • [二. 初始化项目](#二. 初始化项目)
  • [三. 项目代码](#三. 项目代码)
    • [3.1 `Tool.cs`主类](#3.1 Tool.cs主类)
    • [3.2 `AssemblyInfo.cs`配置类](#3.2 AssemblyInfo.cs配置类)
  • [四. 编译](#四. 编译)
  • [五. 将`.dll`类库注册到系统](#五. 将.dll类库注册到系统)
  • [六. vba中使用](#六. vba中使用)

一. 需求

🔷写vba代码的时候,会想下面这样使用CreateObject创建一个对象,然后使用其中的方法

vbnet 复制代码
Sub SendGetRequest()

    Const url = "https://api.github.com"

    ' 创建http请求对象
    Dim http As Object
    Set http = CreateObject("WinHttp.WinHttpRequest.5.1")

    ' 发送get请求
    http.Open "GET", url, False
    http.Send

    Debug.Print http.ResponseText

End Sub

🔷先要求在vba中使用CreateObject("ToolLib.ToolCom")创建一个对象,然后使用其中的方式。

vbnet 复制代码
Sub MainSub()

    Dim obj As Object
    Set obj = CreateObject("ToolLib.ToolCom")

    MsgBox obj.Hello("World")
    MsgBox obj.Add(3, 5)

End Sub

🔷用C# 写一个能被VBA调用的COM组件,把.NET类暴露成COM可见对象。

  • C#写类
  • 标记为COM可见
  • 编译成DLL
  • 注册到系统(regasm)
  • VBA 通过CreateObject调用

二. 初始化项目

🔷创建一个类库

csharp 复制代码
dotnet new classlib -n ToolLib

🔷修改.csproj文件如下所示

csharp 复制代码
<Project Sdk="Microsoft.NET.Sdk">

  <PropertyGroup>
	<!-- 推荐用 .NET Framework -->
    <TargetFramework>net48</TargetFramework>
	<!-- 关闭自动注册 -->
    <RegisterForComInterop>false</RegisterForComInterop>
	<!-- 关闭自动生成AssemblyInfo -->
	<GenerateAssemblyInfo>false</GenerateAssemblyInfo>
	<!-- 不输出调试信息 -->
    <DebugType>none</DebugType>
  </PropertyGroup>

</Project>

三. 项目代码

3.1 Tool.cs主类

🔷Tool.cs

  • [ComVisible(true)]:设置Com可见, 否则vba无法使用
  • [Guid("xxxxx-xxxx-xxxx-xxxxxxx")]:类库的唯一标识符,可以使用 Visual Studio 生成。
csharp 复制代码
using System.Runtime.InteropServices;

namespace ToolLib
{
	[ComVisible(true)]
	[Guid("1D4C98EC-D988-4D6C-8DD6-189E238D7B4E")]
	[InterfaceType(ComInterfaceType.InterfaceIsDual)]
	public interface IToolCom
	{
		int Add(int a, int b);
		string Hello(string name);

	}

	[ComVisible(true)]
	[Guid("6143FB0B-9C17-4859-860C-6DA4A466ECD1")]
	// 显示声明ProgId, 便于vba通过 CreateObject("ToolLib.ToolCom") 创建对象
	[ProgId("ToolLib.ToolCom")]
	[ClassInterface(ClassInterfaceType.None)]
	public class ToolCom : IToolCom
	{
		public int Add(int a, int b)
		{
			return a + b;
		}

		public string Hello(string name)
		{
			return $"Hello, {name}";
		}
	}
}

🔷生成GUID的方法

3.2 AssemblyInfo.cs配置类

csharp 复制代码
using System.Reflection;
using System.Runtime.InteropServices;

// 文件→属性→详细信息→文件说明
[assembly: AssemblyTitle("ToolLib_Test")]
// vba→工具→引用 时显示的信息
[assembly: AssemblyDescription("FengYeHong VBA COM Library")]
[assembly: AssemblyCompany("FengYeHong-Company")]
// 文件→属性→详细信息→产品名称
[assembly: AssemblyProduct("ToolLib_for_vba")]

// 非常重要
// 类型库 GUID
[assembly: Guid("9F3E7D2C-1234-4A56-8888-ABCDEF123456")]

// 文件→属性→详细信息→产品版本
[assembly: AssemblyVersion("1.0.0.1")]

四. 编译

🔷该工程要生成的是一个类库,因此需要通过编译生成所需的.dll文件


五. 将.dll类库注册到系统

🔷篇幅较长,不在此篇文章展开,详情请参考下面这篇文章。

Powershell 注册.dll类库到系统


六. vba中使用

🔷当.dll类库注册到系统之后,vba就可以正常使用该类库了。

相关推荐
专注VB编程开发20年2 小时前
python翻译网页HTML的难题
python·c#·html
z落落3 小时前
C# 抽象类(abstract)
java·开发语言·c#
unityのkiven4 小时前
工作分享1(26.5.27):基于栈实现全局返回逻辑通用架构设计(适配异步 + 确认弹窗)
游戏·unity·c#·客户端架构
z落落5 小时前
C# 多态 + 函数重载(静态多态)+运算符重载
开发语言·c#
Fms_Sa5 小时前
分治法—最大子段问题
算法·c#
rick9775 小时前
C# 动态对象实战:用 DynamicObject 打造你的"万能插件架构"
c#
玩c#的小杜同学6 小时前
未来 AI 会装进电脑里吗?本地 AI、AI PC 和企业隐私计算
人工智能·微软·c#·电脑·英伟达
荔枝吻6 小时前
【保姆级喂饭教程】Inno Setup下载安装、添加中文、打包、自动化教程
c#·vs·inno setup
蜗牛~turbo6 小时前
金蝶云星空 二开得到来源单单据体2数据包
windows·c#·金蝶·dynamicobject
雪豹阿伟7 小时前
14.C# —— 静态成员、只读常量、继承、访问修饰符、多态、抽象类
c#·上位机