在下面的代码中,我成功地在 C# 中使用 Microsoft 的System.Linq.Dynamic来评估类似于 Javascript 的字符串表达式eval()
。但是,我无法弄清楚在调用新函数时如何保证参数名称和相应的值匹配。 "SKU + \" \" + Name"
可以1234 Cola
像Cola 1234
. 我有几十个参数。
System.Dynamic.Linq 的Parse
方法用于Dictionary<string,object>
在内部保存参数,这是我的问题,因为 Dictionary 不保证像数组和列表这样的顺序。 我假设因为 Microsoft 选择使用 Dictionary,所以必须对下面的代码进行一些简单的修复,以确保参数值匹配。 在 LinqPad 中输入了代码。
命名参数是否可能像Name: "Cola", SKU: "1234"
?是否有一些数据类型或技术可以用来保证参数名称和值匹配?这是否需要更改 Microsoft 的代码来替换 Dictionary?
var symbols = new Dictionary<String, Object>(); // Cannot change symbols datatype
var paramExp = new List<ParameterExpression>();
var paramVal = new List<String>();
var fields = new Dictionary<String,String>(); // Sample Data
fields["SKU"] = "1234";
fields["Name"] = "Cola";
fields["Type"] = "Drink";
var expression = "SKU + \" \" + Name";
foreach( var f in fields) { // Setup Parameters
ParameterExpression x =
Expression.Parameter(Type.GetType("System.String"), f.Key);
symbols.Add( f.Key, x);
paramExp.Add( x);
paramVal.Add( f.Value);
}
Expression body = System.Linq.Dynamic.DynamicExpression.Parse(
Type.GetType("System.String"), expression, symbols);
LambdaExpression e = Expression.Lambda(body,
paramExp.ToArray()); // Order may not match body
var c = e.Compile();
c.DynamicInvoke(paramVal.ToArray()); // Same here ... possible order mismatch
// c.Dump(); // outputs "1234 Cola"
以下是上述和 System.Linq.Dynamic 的用法:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Linq.Dynamic;
using System.Reflection;
using System.Reflection.Emit;
using System.Text;
using System.Threading;