我遇到的情况是我正在查询MongoDB,其字符串是对象层次结构中超过一级深度的字段。此查询必须是字符串。例如,我在Groovy中查询类似的内容:
def queryField = 'a.b.c' //this is variable and can be different every time
def result = mongodb.collection.findOne([queryField:5])
问题没有出现在结果中我想找到嵌套字段的值。使用GPath,我可以深入一级并获得一个值这样做
def aObj = result."a" //or result["a"]
然而,我希望通过做这样的事情来深入研究:
def queryField = "a.b.c" //this can change every time and is not always 'a.b.c'
def cObj = result[queryField] //since field is variable, can't just assume result.a.b.c
这在Groovy中不起作用。记录了一个错误here,但我想知道是否有更好的解决方案来使用这个场景比我通过拆分点然后构建对象遍历来解析字符串更清晰。注意,“a.b.c”在运行时是可变的和未知的(例如它可能是“a.b.d”)。
答案 0 :(得分:2)
根据错误/线程,支持点属性访问器会出现一些模糊问题。基于邮件列表线程,似乎评估queryField字符串将是您最好的选择:
def result = [a: [b: [c: 42]]]
def queryString = 'a.b.c'
def evalResult = Eval.x(result, 'x.' + queryString)
assert evalResult == 42
邮件列表线程有点旧,所以有一个新的(至少1.7.2)Eval类可以帮助运行没有大绑定的小片段。
否则,您可以拆分字符串并递归地对对象执行属性评估,从而有效地再现GPath遍历行为的子集。