C#编写自定义Excel公式计算非均匀现金流的NPV与IRR

1、用Visual Studio新建一个类库,命名为CashFlowTools



2、引用必要的类库:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.InteropServices;
using Microsoft.Win32;
using Microsoft.Office.Interop.Excel;

其中最后一个需要在“引用”中添加一个COM组件“Microsoft.Office.Interop.Excel”


3、添加COM相关属性

[Guid("DDE8AA59-9860-44B3-B1AF-923ABB4A8EEE")] 
[ClassInterface(ClassInterfaceType.AutoDual)] 
[ComVisible(true)] 

注意要生成一个GUID:


这里我使用的LinqPad,一个轻量级的IDE,支持C#、VB.NET、Linq、F#、SQL语句,非常适合用来测试少量代码。


4、添加COM的注册和反注册函数,这两个函数代码是固定的。添加后的程序结构如下

namespace CashFlowTools
{
    [Guid("DDE8AA59-9860-44B3-B1AF-923ABB4A8EEE")]
    [ClassInterface(ClassInterfaceType.AutoDual)]
    [ComVisible(true)] 
    public class CashFlowTools
    {
        #region COM related
        [ComRegisterFunction]
        public static void RegisterFunction(Type type)
        {
            Registry.ClassesRoot.CreateSubKey(GetSubKeyName(type, "Programmable"));
            var key = Registry.ClassesRoot.OpenSubKey(GetSubKeyName(type, "InprocServer32"), true);
            key.SetValue("", Environment.SystemDirectory + @"\mscoree.dll", RegistryValueKind.String);
        
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值