1. 程式人生 > >自定義公式計算

自定義公式計算

形式 prope math.sqrt 換行 script bubuko mod contain exec

思路,關鍵字段可以寫死或是以字典的形式存在;技術分享圖片這個就是關鍵字段。

然後保存自定義公式,我是以生產一個中文公式(字段中文名),然後按中文公式生產英文的公式(字段名),然後保存公式所引用的字段(英文名,以逗號分隔,換行符,這裏只是用來區分字段),保存前先測試算下公式。

最後上代碼,添加引用技術分享圖片

/// <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)));
}
}
}

自定義公式計算