zoukankan      html  css  js  c++  java
  • 自定义公式计算

    思路,关键字段可以写死或是以字典的形式存在;这个就是关键字段。

    然后保存自定义公式,我是以生产一个中文公式(字段中文名),然后按中文公式生产英文的公式(字段名),然后保存公式所引用的字段(英文名,以逗号分隔,换行符,这里只是用来区分字段),保存前先测试算下公式。

    最后上代码

    添加COM引用:

    /// <param name="model">数据</param>

    /// <param name="formual">公式</param>
    /// <param name="fields">字段集合,以逗号分隔</param>
    private decimal ProcessData<T>(T t, string formual, string fields)
    {
           MSScriptControl.ScriptControl scp = new MSScriptControl.ScriptControl();
           scp.Language = "JavaScript";
           StringBuilder sb = new StringBuilder();
            //下面的变量你自己设计
           //sb.Append("var e=9;");
           ProcessVariables(t, sb, fields);
           scp.ExecuteStatement(sb.ToString());//加入脚本
           //string formula = "Math.sqrt(a+b)*c*Math.pow(d,3)/e";//公式
           //formual;公式
           return (decimal)scp.Eval(formual);//计算结果

    }

    private void ProcessVariables<T>(T t, StringBuilder sb, string fields)
    {
          foreach (PropertyDescriptor pd in TypeDescriptor.GetProperties(typeof(T)))
          {
               if (fields.Contains(pd.Name))//存在该字段就赋值
               {
                   sb.Append(string.Format("var {0}={1};", pd.Name, pd.GetValue(t)));
               }
         }
    }

  • 相关阅读:
    PAT乙级1002. 写出这个数 (20)
    PAT乙级1001. 害死人不偿命的(3n+1)猜想 (15)
    HDU 4520 小Q系列故事——最佳裁判
    POJ 3414 Pots(BFS)
    POJ 1118 Lining Up
    POJ 2484 A Funny Game
    POJ 2231 Moo Volume
    HDU 5718 Oracle(高精度)
    FZU 1502 Letter Deletion(DP)
    HDU 1564 Play a game
  • 原文地址:https://www.cnblogs.com/shuaimeng/p/9722332.html
Copyright © 2011-2022 走看看