社区
C#
帖子详情
计算公式问题
piaoyu581
2006-03-13 11:33:53
我现在有一个公式是字符串类型:“(2+3)/4-1”,我想求的计算结果
是不是一定要按运算符分解开转化成相应的类型,才可以啊?
有没有方便一点的办法啊?
...全文
253
9
打赏
收藏
计算公式问题
我现在有一个公式是字符串类型:“(2+3)/4-1”,我想求的计算结果 是不是一定要按运算符分解开转化成相应的类型,才可以啊? 有没有方便一点的办法啊?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
9 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
LixingTie
2006-03-13
打赏
举报
回复
吼吼~~~~~应各位要求,改了一下,下面是.Net framework 1.1版本的,感谢各位的支持!!
using System;
using System.CodeDom.Compiler;
using System.Reflection;
using System.Text;
using Microsoft.CSharp;
namespace Expression
{
/// <summary>
/// 计算表达式的类
/// </summary>
public class CalculateExpression
{
/// <summary>
/// 接受一个string类型的表达式并计算结果,返回一个object对象,静态方法
/// </summary>
/// <param name="expression"></param>
/// <returns></returns>
public static object Calculate(string expression)
{
string className = "Calc";
string methodName = "Run";
expression = expression.Replace("/", "*1.0/");
// 创建编译器实例。
ICodeCompiler complier = (new CSharpCodeProvider().CreateCompiler());
// 设置编译参数。
CompilerParameters paras = new CompilerParameters();
paras.GenerateExecutable = false;
paras.GenerateInMemory = true;
// 创建动态代码。
StringBuilder classSource = new StringBuilder();
classSource.Append("public class " + className + "\n");
classSource.Append("{\n");
classSource.Append(" public object " + methodName + "()\n");
classSource.Append(" {\n");
classSource.Append(" return " + expression + ";\n");
classSource.Append(" }\n");
classSource.Append("}");
// 编译代码。
CompilerResults result = complier.CompileAssemblyFromSource(paras, classSource.ToString());
// 获取编译后的程序集。
Assembly assembly = result.CompiledAssembly;
// 动态调用方法。
object eval = assembly.CreateInstance(className);
MethodInfo method = eval.GetType().GetMethod(methodName);
object reobj = method.Invoke(eval, null);
GC.Collect();
return reobj;
}
}
}
本人QQ 260031207 欢迎来交流!!
Montaque
2006-03-13
打赏
举报
回复
http://montaque.cnblogs.com/archive/2005/12/28/306407.html
piaoyu581
2006-03-13
打赏
举报
回复
汗。。。1.1框架CodeDomProvider好象不包含对CompileAssemblyFromSource的定义哦
piaoyu581
2006-03-13
打赏
举报
回复
谢二楼的了~~不过我的项目是VS2003的~~~
先试下再说~
LixingTie
2006-03-13
打赏
举报
回复
顺便说一句,这个类的代码是C#2.0环境下的,用VS2003运行可能会报错,建议用VS2005
LixingTie
2006-03-13
打赏
举报
回复
该类的Calculate方法接收一个string字符串,通过编译器编译计算出结果,返回一个object值。楼主的问题只要调用该类的Calculate方法把字符串传进去就可以了。
string str = "(2+3)/4-1";
double result;
result = (double) Expression.CalculateExpression.Calcualte(str);
该类也可以计算其它类型的表达式。例如调用方法传进字符串"3>2",则返回true;
hyena041
2006-03-13
打赏
举报
回复
赞一下,2楼的东西,收藏了
呵呵
LixingTie
2006-03-13
打赏
举报
回复
本人收集了一个类,是用来计算字符串格式的表达式的。
using System;
using System.CodeDom.Compiler;
using System.Reflection;
using System.Text;
using Microsoft.CSharp;
namespace Expression
{
/// <summary>
/// 计算表达式的类
/// </summary>
public class CalculateExpression
{
/// <summary>
/// 接受一个string类型的表达式并计算结果,返回一个object对象,静态方法
/// </summary>
/// <param name="expression"></param>
/// <returns></returns>
public static object Calculate(string expression)
{
string className = "Calc";
string methodName = "Run";
expression = expression.Replace("/", "*1.0/");
// 创建编译器实例。
CodeDomProvider complier = (new Microsoft.CSharp.CSharpCodeProvider());
// 设置编译参数。
CompilerParameters paras = new CompilerParameters();
paras.GenerateExecutable = false;
paras.GenerateInMemory = true;
// 创建动态代码。
StringBuilder classSource = new StringBuilder();
classSource.Append("public class " + className + "\n");
classSource.Append("{\n");
classSource.Append(" public object " + methodName + "()\n");
classSource.Append(" {\n");
classSource.Append(" return " + expression + ";\n");
classSource.Append(" }\n");
classSource.Append("}");
// 编译代码。
CompilerResults result = complier.CompileAssemblyFromSource(paras, classSource.ToString());
// 获取编译后的程序集。
Assembly assembly = result.CompiledAssembly;
// 动态调用方法。
object eval = assembly.CreateInstance(className);
MethodInfo method = eval.GetType().GetMethod(methodName);
object reobj = method.Invoke(eval, null);
GC.Collect();
return reobj;
}
}
}
piaoyu581
2006-03-13
打赏
举报
回复
谢楼上的了~~~看来偶这方面的知识要好好补补了~~~
结帐
Excel公式入门实战视频课程【你学得会】
而这里我们所说的Excel公式一般是指
计算公式
,包括常用的四则运算和函数的使用。通过这些运算,我们能从普通数据中得到计算结果以满足分析需求。从而进一步推敲具体的实施方案。杨老师通过《Excel公式实战视频课程...
关于java使用poi导出excel跨sheet页
计算公式
问题
要在excel单元格中使用
计算公式
,需要在单元格中写入对应的公式:cell.setCellFormula(excelCellTemp.getCellFormula());并将表格的强制计算打开// 强制执行计算 sheet.setForceFormulaRecalculation(true);如果要跨...
关于电的计算机公式,电量
计算公式
_有关各类电量的
计算公式
有关电量
计算公式
,怎么计算电量,在电工维护工作中,电量计算知识是必须掌握的,常用的电量
计算公式
有哪些,如何正确计算各类电量的值,电能
计算公式
又有哪些,一起来了解下。一、电量
计算公式
首先:1度电=1千瓦时...
ADC信噪比
计算公式
上面的公式是我们经常见到的ADC信噪比
计算公式
,至于公式为什么而来,度娘虽然给出了一些解答,但是这些解答支离破碎,有些
问题
细节并不丰富,最近在读书的过程中发现书中一章对于该
问题
的描述以及讲解及其详细,...
有功功率
计算公式
和无功功率
计算公式
无功功率(reactive power)在...无功功率
计算公式
无功功率=i*u*sinφ,单位为乏或千乏. 有功功率
计算公式
有功功率p=iucosφ 其实有功功率p、无功功率q、视在功率s就是一直角三角形的三条变:s为斜边,p、q为两直角
C#
110,534
社区成员
642,575
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章