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

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

相关推荐
ᅠᅠᅠ@4 分钟前
异常枚举;
开发语言·javascript·ecmascript
编程版小新10 分钟前
C++初阶:STL详解(四)——vector迭代器失效问题
开发语言·c++·迭代器·vector·迭代器失效
陈大爷(有低保)24 分钟前
UDP Socket聊天室(Java)
java·网络协议·udp
c4fx29 分钟前
Delphi5利用DLL实现窗体的重用
开发语言·delphi·dll
kinlon.liu37 分钟前
零信任安全架构--持续验证
java·安全·安全架构·mfa·持续验证
鸽芷咕1 小时前
【Python报错已解决】ModuleNotFoundError: No module named ‘paddle‘
开发语言·python·机器学习·bug·paddle
王哲晓1 小时前
Linux通过yum安装Docker
java·linux·docker
Jhxbdks1 小时前
C语言中的一些小知识(二)
c语言·开发语言·笔记
java6666688881 小时前
如何在Java中实现高效的对象映射:Dozer与MapStruct的比较与优化
java·开发语言
Violet永存1 小时前
源码分析:LinkedList
java·开发语言