自定义公式计算

Posted shuaimeng

tags:

篇首语:本文由小常识网(cha138.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)));
           }
     }
}

 























以上是关于自定义公式计算的主要内容,如果未能解决你的问题,请参考以下文章

自定义公式计算

在自定义列中编辑简单运算公式(Power Query 之 M 语言)

在 Apache Spark Python 中自定义 K-means 的距离公式

创建Salesforce自定义公式字段 - (错误参数类型错误)

如何用C++编写交互程序,界面上允许用户自定义变量公式等等function

PowerQuery处理透视表总计行不能自定义计算