小编Mar*_*ene的帖子

KDB/Q:如何循环没有循环?

我在kdb数据库上学习q.我担心q中没有循环这一事实.我需要编写一个算法,我会在像C这样的详细程序中用几个嵌套的for循环编写.但是在q中我被不能循环的事实所困扰.

只是给出一个具体的例子(其中一个),我有这个简单的向量(列表):

q)closures
price
-----
18.54
18.53
18.53
18.52
18.57
18.9 
18.9 
18.77
18.59
18.51
18.37
Run Code Online (Sandbox Code Playgroud)

我需要一个向3by3这些条目组合的向量,具有叠加,如(使用R语法):闭包[0:2],闭包[1:3],闭包[2:4],闭包[3:5] ......我能怎么做?

一般来说,我如何改变自己的心态,正确编程?

非常感谢您对Marco的建议

kdb

8
推荐指数
2
解决办法
1万
查看次数

使用q在函数内部定义函数时的变量可见性

我正在定义一个函数,其中包含另一个函数:

find_badTicks:{ [tab;sec] // dummy function, for debug..
  Ndays: 10i ;
  dates: select distinct date from tab where sym = sec ;
  closures: select last price by date from tab where sym = sec ;
  returns: 1 _ select ( (price)-(prev price) )%(prev price)  from closures  ;
  stdevs: {[x;y] sd[ (Ndays-1)#y _ x ] } [ (returns)[;`price] ] each til ( (1 - (Ndays-1)) + count (returns)[;`price] ) ;
  :tab 
}
Run Code Online (Sandbox Code Playgroud)

如果我编译该函数,它将起作用。如果我一行一行地运行,那行得通。但是,如果尝试调用该函数,则会出现错误:

  q)testTab: find_badTicks [testTab ; `ENI.IM.Equity] ;
  'Ndays
Run Code Online (Sandbox Code Playgroud)

如果我在嵌套函数中删除Ndays,显式编写为10,则它可以工作。是的,我想这是嵌套函数内部的局部变量可见性的问题,在函数执行中:即嵌套函数看不到Ndays,这是函数find_badTicks的局部变量。您知道如何在内部函数中使Ndays可见吗?谢谢马可

kdb

5
推荐指数
1
解决办法
3444
查看次数

标签 统计

kdb ×2