any

语法

any(func, args...)

详情

把函数应用到参数的每一个元素。只要函数调用返回true,any 高阶函数就会停止执行,并返回true。如果所有的函数调用都返回false,any 高阶函数将返回false。

如果args是一个矩阵,any模 板将会按列执行;如果args是一个表格,它将会按行执行。

参数

  • func 是一个函数名。
  • args 是函数F的参数。它们可以是向量、矩阵或表。它们的数据形式可以不尽相同,但是长度必须相同,即向量中元素的个数,或矩阵中列的数量,或表中行的数量必须相同。

例子

any 高阶函数用于向量:

x = 1 2 3 11 12 13 NULL 102 103;
y = x cut 3;
y;
# output
([1,2,3],[11,12,13],[,102,103])

any(hasNull, y);
# output
1
// 检查是否 [1,2,],[11,,13],[,102,103]中任意一个含有 NULL值

x=1 25 7 15 11 197 16 18 23;
y=x cut 3;
y;
# output
([1,25,7],[15,11,197],[16,18,23])

any(in, 7 8 23, y);
# output
1
// 返回true,因为虽然8不在[15, 11, 197]中, 但7在[1, 25, 7]中

any(in, 8 20 19, y);
# output
0
// 8不在[1, 25, 7]中,20不在[15, 11, 197]中并且19不在[16, 18, 23]中

any(lt, 4 5 6, 1 2 3);
# output
0
// 检查是否4<1, 5<2并且6<3

any(<, 4 5 6, 1 7 3);
# output
1
// 返回true,因为5<7

any 高阶函数用于矩阵,按列遍历。

x=1..6$2:3;
x;
#0 #1 #2
1 3 5
2 4 6
any(in, 6 1 4, x);
# output
0

any(in, 3 4 2, x);
# output
1
// 返回 true,因为4在x的第二列中

any 高阶函数用于数据表,按行遍历。下例中,定义了一个名为 varscompare 的函数用于比较表中的两个变量。

x=table(1 2 3 as a, 4 5 6 as b);
x;
a b
1 4
2 5
3 6
def varscompare(t): t.a>t.b;
any(varscompare, x);
# output
0

y=table(1 7 3 as a, 4 5 6 as b);
y;
a b
1 4
7 5
3 6
any(varscompare, y);
# output
1
// 返回true,因为7>5