在一个程序开发当中,有很多涉及到公式的定义与计算,在用户给定的文档中,公式采用字符串形式定义,包含了一些变量名和各种运算符号,程序需要先进行字符变量的值替换后再进行计算,取得结果后再进行后续的操作。
这个动态字符串公式的自动计算以前遇到过,在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#的动态编译执行代码的功能来实现,就是将字符串公式包装成一个可以编译的代码块,然后使用动态编译将它编译成可执行的代码从而获取计算结果,这个技术有点麻烦。
动态编译这一项技术很实用,值得深入学习和掌握。