思路,关键字段可以写死或是以字典的形式存在;这个就是关键字段。
然后保存自定义公式,我是以生产一个中文公式(字段中文名),然后按中文公式生产英文的公式(字段名),然后保存公式所引用的字段(英文名,以逗号分隔,换行符,这里只是用来区分字段),保存前先测试算下公式。
最后上代码
添加COM引用:
/// <param name="model">数据</param>
//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)));
}
}
}