.Net实现表达式计算(公式) 表达式字符串
文档原址:http://blog.csdn.net/fangxing80/article/details/5992661
实现复杂公式计算,比如含IF分支判断等,可考虑通过调用EXCEL公式获取值。
Excel公式计算参考:http://www.cnblogs.com/senyier/p/3498526.html
方法一: MSScriptControl.ScriptControl
VB.NET
- Dim exp As String = "3 + 4"
- Dim t As Type = Type.GetTypeFromProgID("MSScriptControl.ScriptControl")
- Dim obj As Object = Activator.CreateInstance(t)
- t.InvokeMember("Language", System.Reflection.BindingFlags.SetProperty, _
- Nothing, obj, New Object() {"vbscript"})
- Dim result As Object = t.InvokeMember("Eval", System.Reflection.BindingFlags.InvokeMethod, _
- Nothing, obj, New Object() {exp})
- MsgBox("method 1: " & CStr(result))
C#
- var exp = "3 + (2 + 3)/5";
- var type = Type.GetTypeFromProgID("MSScriptControl.ScriptControl");
- var obj = Activator.CreateInstance(type);
- type.InvokeMember("Language", BindingFlags.SetProperty, null,
- obj, new object[] { "javascript" });
- var result = type.InvokeMember("Eval", BindingFlags.InvokeMethod, null,
- obj, new object[] { exp });
- Console.WriteLine("{0} = {1}", exp, result);
方法二: CodeDOM
VB.NET
- Dim oCodeProvider As VBCodeProvider = New VBCodeProvider
- Dim oCParams As CompilerParameters = New CompilerParameters
- Dim oCResults As CompilerResults = Nothing
- Dim oAssy As System.Reflection.Assembly = Nothing
- Dim oExecInstance As Object = Nothing
- Dim oRetObj As Object = Nothing
- Dim oMethodInfo As MethodInfo = Nothing
- Dim oType As Type = Nothing
- Dim strSource As String = _
- "Public Class MainClass " + vbCrLf + _
- " Public Shared Function Eval() As Integer" + vbCrLf + _
- " Return 3 + 4" + vbCrLf + _
- " End Function" + vbCrLf + _
- "End Class"
- oCParams.CompilerOptions = "/t:library"
- oCParams.GenerateInMemory = True
- oCResults = oCodeProvider.CompileAssemblyFromSource(oCParams, strSource)
- If oCResults.Errors.Count <> 0 Then
- MsgBox("Error")
- End If
- oAssy = oCResults.CompiledAssembly
- 'oExecInstance = oAssy.CreateInstance("MainClass")
- 'oType = oExecInstance.GetType
- 'oMethodInfo = oType.GetMethod("Eval")
- 'oRetObj = oMethodInfo.Invoke(oExecInstance, Nothing)
- oType = oAssy.GetType("MainClass")
- oRetObj = oType.InvokeMember("Eval", BindingFlags.InvokeMethod, Nothing, Nothing, Nothing)
- MsgBox("method 2: " & CStr(oRetObj))
C#
- var exp = "3 + (2 + 3)/5";
- var csCodeProvider = new CSharpCodeProvider();
- var csParams = new CompilerParameters();
- var source = "public class MainClass { public static object Eval() { return (#exp#); } }";
- source = source.Replace("#exp#", exp);
- csParams.CompilerOptions = "/t:library";
- csParams.GenerateInMemory = true;
- var csResults = csCodeProvider.
- CompileAssemblyFromSource(csParams, source);
- if (csResults.Errors.Count > 0)
- {
- Console.WriteLine(csResults.Errors[0].ToString());
- return;
- }
- var ass = csResults.CompiledAssembly;
- var type = ass.GetType("MainClass");
- var result = type.InvokeMember("Eval", BindingFlags.InvokeMethod,
- null, null, null);
- Console.WriteLine("{0} = {1}", exp, result);
方法三: DataColumn.Expression & DataTable.Compute方法。
VB.NET
- Dim dt As DataTable = New DataTable
- dt.Columns.Add("Val1", GetType(Integer))
- dt.Columns.Add("Val2", GetType(Integer))
- dt.Columns.Add("Result").Expression = String.Format("Val1 + Val2", Me.TextBox1.Text)
- dt.Rows.Add(New Object() {3, 4})
- MsgBox("method 3: " & dt.Rows(0)("Result"))
C#
- var exp = "3 + (2 + 3)/5";
- DataTable dt = new DataTable();
- dt.Columns.Add("Result").Expression = exp;
- dt.Rows.Add(dt.NewRow());
- var result = dt.Rows[0]["Result"];
- Console.WriteLine("{0} = {1}", exp, result);
.Net实现表达式计算(公式) 表达式字符串的更多相关文章
- LeetCode_p150_逆波兰表达式计算/后缀表达式计算
有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话说,表达式总会得出有效数值且不存在除 ...
- PHP 实现字符串表达式计算
什么是字符串表达式?即,将我们常见的表达式文本写到了字符串中,如:"$age >= 20",$age 的值是动态的整型变量. 什么是字符串表达式计算?即,我们需要一段程序来执 ...
- .NET平台开源项目速览(8)Expression Evaluator表达式计算组件使用
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Expression Evaluator验证组件.那里只是概述了一下,并没有对其使用和强大功能做 ...
- Java堆栈的应用2----------中缀表达式转为后缀表达式的计算Java实现
1.堆栈-Stack 堆栈(也简称作栈)是一种特殊的线性表,堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置进行插入和删除操作,而堆栈只允许在固定一端进行插入和删除 ...
- 《java数据结构与算法》笔记-CH4-8栈结构实现后缀表达式计算结果
/** * 中缀表达式转换成后缀表达式: 从输入(中缀表达式)中读取的字符,规则: 操作数: 写至输出 左括号: 推其入栈 右括号: 栈非空时重复以下步骤--> * 若项不为(,则写至输出: 若 ...
- C# - 二叉树表达式计算
很早以前就写过双栈的表达式计算. 这次因为想深入学一下二叉树,网上都是些老掉牙的关于二叉树的基本操作. 感觉如果就学那些概念,没意思也不好记忆.于是动手写了一个表达式计算的应用例子. 这样学习印象才深 ...
- c语言,中缀表达式转后缀表达式并计算
//c语言中缀表达式计算 #include <stdio.h> #include <stdlib.h> #include <string.h> #include & ...
- C++实现 逆波兰表达式计算问题
C++实现 逆波兰表达式计算问题 #include <iostream> #include <string> using namespace std; class Stack ...
- NYOJ 305 表达式求值 (字符串处理)
题目链接 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min(20,23)的值是20 ,add(10,98) 的值是108等等.经过训练, ...
随机推荐
- 常用数据库validationQuery语句
validationQuery是用来验证数据库连接的查询语句,这个查询语句必须是至少返回一条数据的SELECT语句.每种数据库都有各自的验证语句,下表中收集了几种常见数据库的validationQue ...
- 在MyBatis中查询数据、涉及多参数的数据访问操作、插入数据时获取数据自增长的id、关联表查询操作、动态SQL、关于配置MyBatis映射没有代码提示的解决方案
1. 单元测试 在单元测试中,每个测试方法都需要执行相同的前置代码和后置代码,则可以自定义2个方法,分别在这2个方法中执行前置代码和后置代码,并为这2个方法添加@Before和@After注解,然后, ...
- redis sortedSet
zset 和set 相比: zset 类型和set类型一样,不允许有重复的元素.zset是有序的,zset 有一个double类型的分数,这个分数可以重复,zset正是通过这个分数对集合中的元素从小到 ...
- python读取shp
sf = shapefile.Reader("res2_4m.shp") records = sf.records() print sf.fields for record in ...
- Oracle 数据库执行慢SQL
) hou, - ))) mini, c.sql_address, c.inst_id,f.full_name,u.user_name, b.user_concurrent_program_name, ...
- SQL Server ->> 查询添加XLOCK表提示不阻塞其他线程
BEGIN TRAN BEGIN END DROP TABLE IF EXISTS tempdb..#t CREATE TABLE #t ( spid int, dbid int, ObjId int ...
- 如何让chrome浏览器自动翻译
我用的chrome浏览器,最初用的时候浏览器默认自动翻译英文,我感觉很麻烦.所以我选择了一律不翻译.但是我当我想翻译的的时候又不知道怎么操作.一直郁闷到现在.今天我突然发现了一个方法可以让你的浏览器自 ...
- [翻译] CHTCollectionViewWaterfallLayout
CHTCollectionViewWaterfallLayout https://github.com/chiahsien/CHTCollectionViewWaterfallLayout CHTCo ...
- [翻译] ZCSHoldProgress
ZCSHoldProgress 以下是使用效果: https://github.com/zshannon/ZCSHoldProgress "Your users be pressin' lo ...
- Linux 系统常见命令功能大全_【all】
Linux常见快捷键(6个) ctrl + u:剪贴光标前面 ctrl + k:剪贴光标后面 ctrl + y:粘贴 ctrl + r:查找命令 ctrl + insert:复制 shift+ ins ...