为什么在函数内用parseExpr执行会报SQL context is not initialized yet
在DolphinDB GUI内执行下面代码:
def yoy_continuous_validation(X, threshold, validation_way, continuous_len){
if (not(string(validation_way) in ['>','>=','<','<=','='])){
return NULL
}
m = parseExpr("iif(msum(iif(yoy(X)" + iif(string(validation_way) == "=","==",validation_way) + "threshold,1,0),continuous_len) == continuous_len,1,0)").eval()
return m
}
报错SQL context is not initialized yet,parseExpr拼接的语句为
iif(msum(iif(yoy(X)>threshold,1,0),continuous_len) == continuous_len,1,0)
直接执行不会报错,是什么原因?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
如DolphinDB用户手册中所述,parseExpr函数解析变量时,首先搜索会话中的局部变量,再搜索共享变量,但不会搜索函数体内定义的局部变量。这里是因为parseExpr中用到了函数参数变量X的缘故。代码优化可如下所示: