是否可以在JSONiq/Zorba脚本中打印到控制台进行调试?
例如:
declare function utils:lowerCaseKey($obj as item) as item{
print($obj)
{|
for $k in distinct-values(keys( $obj ))
return { lower-case($k) : $obj.$k } (: note the ',' to create a sequence :)
|}
};发布于 2018-05-23 06:28:46
是的:trace函数满足这个目的。可以在需要查看输出的任何表达式上调用它,以及您选择的标签。
declare function utils:lowerCaseKey($obj as item) as item
{
{|
for $k in distinct-values(keys( trace($obj, "obj") ))
return { lower-case($k) : $obj.$k }
(: note the ',' to create a sequence :)
|}
};这将导致输出,例如:
obj [1]: { "foo" : "bar" }
obj [2]: { "foo" : "bar2" }准确地(在命令行中,在日志文件中)这个输出应该被记录在每个引擎中。在默认情况下,Zorba将输出到stderr。
请注意,这是一种声明性语言,因此trace的行为与print不同。如果不需要,可以对某些表达式进行优化,在这种情况下,它不会生成跟踪。例如,
(1, trace(2, "foo"))[1]可能不会产生任何痕迹。同样,生成跟踪的顺序可能依赖于实现,因为JSONiq和XQuery一样,只要其结果符合规范,每个引擎就可以自由地计算最佳表达式。
https://stackoverflow.com/questions/50473718
复制相似问题