zoukankan      html  css  js  c++  java
  • C#中 字符串转换为计算公式,并计算结果

           根据总结,大概分为以下三种:

        第一种: 用DataTable中的Compute方法。

        例如:" 1*2*3 "

        代码如下:

       var a = new System.Data.DataTable().Compute("1*2*3", ""); 
       //结果a=>6

        第二种:利用javascript中的Eval方法解析.此方法需引入添加COM引用:Microsoft Sctipt Control 1.0  

            在使用过程中,若出现无法嵌入互操作类型“MSScriptControl.ScriptControlClass”,则可以这样操作。右击MSScriptControl程序集--〉属性--〉嵌入互操作类型--〉改为false

            让我们看下这个方法的强大之处:

            例如:"1*2*3"

            此方法还能解析像这种等字符串 :“if(3>2){  1 }else {  2}”

        代码如下:

     MSScriptControl.ScriptControl sc = new MSScriptControl.ScriptControlClass();
                    sc.Language = "javascript";
                    var b = sc.Eval("1*2*3");
        //结果b=>6

        第三种: 引入添加.net 引用 Microsoft.JScript 和Microsoft.Vsa 

            个人认为此方法跟方法二是一样的,具体区别不清楚 

            例如:"1*2*3"

            此方法还能解析像这种等字符串 :“if(3>2){  1 }else {  2}”,跟方法二一样。

        代码如下:

        

     Microsoft.JScript.Vsa.VsaEngine ve = Microsoft.JScript.Vsa.VsaEngine.CreateEngine();
                    var c = Microsoft.JScript.Eval.JScriptEvaluate("1*2*3", ve);  
        //结果c=>6

        总结,项目中难免会出现类似这种情况,我个人认为,如果只是简单的计算,第一种无疑是最方便的,若是有逻辑的字符串需要解析,就用第二种或者是第三种。

        个人喜欢。

        本文到此结束。谢谢观赏。

     

  • 相关阅读:
    关于document.body.scrollLeft总是0的原因
    转载:如何配置 SQL Server 2005 以允许远程连接
    【转载】SQL Server中Rollup关键字使用技巧
    JavaScript代码优化
    JavaScript中定义类或对象
    【转载】SQLServer2005 Pivot 转置使用动态列
    迅雷刷分
    ROW_NUMBER() OVER函数的基本用法用法
    FireFox下表单无法刷新重置的解决
    SQL 远程查询
  • 原文地址:https://www.cnblogs.com/wzf-Code/p/5776342.html
Copyright © 2011-2022 走看看