C#编程中字符串公式的计算

  在一个程序开发当中,有很多涉及到公式的定义与计算,在用户给定的文档中,公式采用字符串形式定义,包含了一些变量名和各种运算符号,程序需要先进行字符变量的值替换后再进行计算,取得结果后再进行后续的操作。

  这个动态字符串公式的自动计算以前遇到过,在JavaScript中或者其他的开发语言如Powerbuilder中有过类似的需求,JavaScript中的比较好解决,Powerbuilder直接使用数据窗口的DS就可以轻松解决。

  所以,首先想到的肯定是使用C#的Datatable。
  1、使用DataTable

            Single msz = 1.5F;
            Single bhcs = 2.1F;
            Single xxpl = 4.7F;
            string  StrResult = "";

            string StrFormula = textBox1.Text.Trim ();
            //变量替换
            StrFormula= StrFormula.Replace("msz",msz.ToString());
            StrFormula = StrFormula.Replace("bhcs", bhcs.ToString());
            StrFormula = StrFormula.Replace("xxpl", xxpl.ToString());
            //开始计算
            DataTable dataTable = new DataTable();
            object result = dataTable.Compute(StrFormula, null);
            StrResult= Convert.ToSingle(result).ToString ();

            //输出
            label3.Text = StrResult;

  2、使用JavaScript也可以,需要添加引用

  在管理NuGet程序包中安装 Microsoft.ClearScript 并在程序中添加引用:

using Microsoft.ClearScript.V8;

  然后就可以在程序中直接调用:

            using (var JSEngine = new V8ScriptEngine())
            {
                object result = JSEngine.Evaluate(StrFormula);
                StrResult= Convert.ToSingle(result).ToString ();
            }

  同样可以得到正确的结果。

  3、使用使用Excel表单元格的计算

  这个也是很容易想到的,安装包EPPlus,因为我的程序是基于.NET Framework,所以安装EPPlus,如果是基于基于 .NET Core,那么就需要安装EPPlus.Core。

  这里有两种方法,一个是在本地新建一个Excel文件供使用,另外直接在内存中创建文件。

  在程序中添加引用:

using OfficeOpenXml;

  代码实现:

            OfficeOpenXml.LicenseContext licenseContext = OfficeOpenXml.LicenseContext.NonCommercial;
            ExcelPackage.LicenseContext = licenseContext;
            using (var package = new ExcelPackage())
            {
                // 添加一个工作表
                var worksheet = package.Workbook.Worksheets.Add("Sheet1");
                // 设置 A1 单元格的公式
                worksheet.Cells["A1"].Formula = StrFormula;
                package.Workbook.CalcMode = ExcelCalcMode.Automatic;
                // 计算公式并获取结果
                worksheet.Calculate();
                // 获取计算后的结果值
                StrResult = worksheet.Cells["A2"].Value.ToString ();
            }

  上面是最容易想到和实现的计算方式,另外也可以使用第三方库来实现,还可以通过C#的动态编译执行代码的功能来实现,就是将字符串公式包装成一个可以编译的代码块,然后使用动态编译将它编译成可执行的代码从而获取计算结果,这个技术有点麻烦。

  动态编译这一项技术很实用,值得深入学习和掌握。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值