为什么在函数内用parseExpr执行会报SQL context is not initialized yet

发布于 2022-09-12 13:19:18 字数 573 浏览 10 评论 0

在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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

世界等同你 2022-09-19 13:19:18

如DolphinDB用户手册中所述,parseExpr函数解析变量时,首先搜索会话中的局部变量,再搜索共享变量,但不会搜索函数体内定义的局部变量。这里是因为parseExpr中用到了函数参数变量X的缘故。代码优化可如下所示:

def yoy_continuous_validation(X, threshold, validation_way, continuous_len){
 cmps = [gt, ge, lt, le, eq]
 index = ['>','>=','<','<=','='].find(string(validation_way))
 if(index < 0)  return NULL
 return  int(msum(cmps[index](yoy(X), threshold), continuous_len) == continuous_len)
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文