1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
USE plato;
$a = (SELECT
skey,count(*) as cnt
FROM Input
GROUP BY Length(key) as skey);
$udfScript = @@
def f(input,x):
for i in list(input):
d = {name: getattr(i, name) for name in i.__class__.__match_args__}
d["pass"] = x
yield d
def f2(a,b,c):
return {"a":a,"b":b,"c":c}
@@;
$udf = Python::f(@@
(Stream<Struct<skey:Uint32,cnt:Uint64>>,Int32)
->
Stream<Struct<skey:Uint32,cnt:Uint64,pass:Int32>>
@@, $udfScript);
$udf2 = Python::f2(@@
(skey:Uint32,cnt:Uint64,pass:Int32)->Struct<a:Uint32,b:Uint64,c:Int32>
@@, $udfScript);
$b = (PROCESS $a USING $udf($ROWS,1));
PROCESS $b USING $udf2(skey,cnt,pass);
|