Преобразование выражения <T, bool> в строку - PullRequest
34 голосов
/ 25 января 2011

Мне нужен способ воссоздать динамически сгенерированные отчеты в какой-то момент в будущем. Короче говоря, мне нужно сохранить определенный запрос linq (различный для каждого отчета) в базе данных, а затем выполнить запрос с динамическим Linq.

Это все хорошо, но я не могу найти способ преобразовать выражение в строку.

Как в:

Expression<Func<Product, bool>> exp = (x) => (x.Id > 5 && x.Warranty != false);

должно стать:

"Product.Id > 5 && Product.Warranty != false"

Есть ли способ сделать это?

1 Ответ

42 голосов
/ 25 января 2011

Возможно, это не лучший / самый эффективный метод, но он работает .

Expression<Func<Product, bool>> exp = (x) => (x.Id > 5 && x.Warranty != false);

string expBody = ((LambdaExpression)exp).Body.ToString(); 
// Gives: ((x.Id > 5) AndAlso (x.Warranty != False))

var paramName = exp.Parameters[0].Name;
var paramTypeName = exp.Parameters[0].Type.Name;

// You could easily add "OrElse" and others...
expBody = expBody.Replace(paramName + ".", paramTypeName + ".")
                 .Replace("AndAlso", "&&");


Console.WriteLine(expBody);
// Output: ((Product.Id > 5) && (Product.Warranty != False))
...