社区
C#
帖子详情
计算公式问题
piaoyu581
2006-03-13 11:33:53
我现在有一个公式是字符串类型:“(2+3)/4-1”,我想求的计算结果
是不是一定要按运算符分解开转化成相应的类型,才可以啊?
有没有方便一点的办法啊?
...全文
281
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
打赏
举报
回复
谢楼上的了~~~看来偶这方面的知识要好好补补了~~~
结帐
关于java使用poi导出excel跨sheet页
计算公式
问题
要在excel单元格中使用
计算公式
,需要在单元格中写入对应的公式:cell.setCellFormula(excelCellTemp.getCellFormula());并将表格的强制计算打开// 强制执行计算 sheet.setForceFormulaRecalculation(true);如果要跨多个sheet页计算,则需要注意出现下面的
问题
:Parse error near char 5 '...
NPOI导出Excel自动
计算公式
问题
以前用过sheet.ForceFormulaRecalculation = true;当时能够自动计算出来。 今天把模板改了一下(没动公式,但是模板是老板改的,我也不知道他操作了什么),结果就不能自动计算了。 最后没办法,只能给每个有公式的单元格处理一下,例如在我的项目里面就是这样的: int[] indexs = new int[] { 5, 7, 9, 13, 15, 17...
ADC信噪比
计算公式
ADC信噪比
计算公式
信噪比
计算公式
:SNRADC=6.02+1.76SNRADC=6.02+1.76SNR_{ADC}=6.02+1.76 上面的公式是我们经常见到的ADC信噪比
计算公式
,至于公式为什么而来,度娘虽然给出了一些解答,但是这些解答支离破碎,有些
问题
细节并不丰富,最近在读书的过程中发现书中一章对于该
问题
的描述以及讲解及其详细,下面只做简单介绍,作为对其他公开资料的补充,有兴趣的同...
圆弧半径计算图解_圆弧
计算公式
及运用[精心整理].doc
圆弧
计算公式
及运用[精心整理]圆弧
计算公式
及运用一. 教学内容:弧长及扇形的面积圆锥的侧面积?二. 教学要求1、了解弧长
计算公式
及扇形面积
计算公式
,并会运用公式解决具体
问题
。2、了解圆锥的侧面积公式,并会应用公式解决
问题
。?三. 重点及难点重点:1、弧长的公式、扇形面积公式及其应用。2、圆锥的侧面积展开图及圆锥的侧面积、全面积的计算。难点:1、弧长公式、扇形面积公式的推导。2、圆锥的侧面积、全面积...
word计算机公式怎么算,word怎么实现自动
计算公式
WORD中能否自动计算,怎么实现Word自动求和?在word中自动求和步骤如下:1、打开一个需要进行数据计算的表格,如下图中,我们 已知五个学生的语文、数学、外语成绩,我们要通过公式完成总分和平均分的计算;2、把光标移动到要求总分的单元格,点击菜单栏的“表格”菜单,执行菜单中的“公式”命令。打开“公式”对话框;3、在打开的“公式”对话框中, 公式中会默认识别我们要计算的数据,一般会识别成求和,如下...
C#
111,120
社区成员
642,537
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章