6

在下面的代码中,我成功地在 C# 中使用 Microsoft 的System.Linq.Dynamic来评估类似于 Javascript 的字符串表达式eval()。但是,我无法弄清楚在调用新函数时如何保证参数名称和相应的值匹配。 "SKU + \" \" + Name"可以1234 ColaCola 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;
4

0 回答 0