我正在寻找一种将条件表达式解析为字符串的方法。
我能想到的最好的例子是 LINQ-to-SQL。它使用 ExpressionVisitor 来格式化“Where”子句。例子:
from a in b where a.x == 5 && a.y < 3 select a
这将转化为以下字符串(大约,MSSQL 对我来说不是最新的):
"SELECT * FROM b WHERE x = 5 AND y < 3"
根据我的阅读,这是使用 ExpressionVisitor 类完成的,如本文所述:链接
现在的问题是我不使用 LINQ,但我需要这个特殊的功能。有没有办法解析这样的条件?我愿意用反射、委托、lambda 等做任何事情。
老实说,我不认为这是可能的,但我的大脑有点炸了(阅读:如果这个问题很荒谬,那就太好了),所以我想我不妨试试 S/O。
编辑:最终用法示例:
// Usage:
foo.Bar(foo => foo.X == 5 && foo.Y < 3)
// Ideal string output (variable name (foo) is not needed):
"foo.X == 5 && foo.Y < 3"
编辑 2:是的,一个数字可以小于 3 等于 5。告诉你我的大脑被炸了。