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#的动态编译执行代码的功能来实现,就是将字符串公式包装成一个可以编译的代码块,然后使用动态编译将它编译成可执行的代码从而获取计算结果,这个技术有点麻烦。

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

相关推荐
Rverdoser2 分钟前
RabbitMQ的基本概念和入门
开发语言·后端·ruby
dj24429457076 分钟前
JAVA中的Lamda表达式
java·开发语言
工业3D_大熊20 分钟前
3D可视化引擎HOOPS Luminate场景图详解:形状的创建、销毁与管理
java·c++·3d·docker·c#·制造·数据可视化
szc176723 分钟前
docker 相关命令
java·docker·jenkins
程序媛-徐师姐33 分钟前
Java 基于SpringBoot+vue框架的老年医疗保健网站
java·vue.js·spring boot·老年医疗保健·老年 医疗保健
yngsqq34 分钟前
c#使用高版本8.0步骤
java·前端·c#
流星白龙36 分钟前
【C++习题】10.反转字符串中的单词 lll
开发语言·c++
尘浮生43 分钟前
Java项目实战II基于微信小程序的校运会管理系统(开发文档+数据库+源码)
java·开发语言·数据库·微信小程序·小程序·maven·intellij-idea
MessiGo44 分钟前
Python 爬虫 (1)基础 | 基础操作
开发语言·python
小白不太白9501 小时前
设计模式之 模板方法模式
java·设计模式·模板方法模式