amis-formula 3.1.0 → 3.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm/doc.js +99 -99
- package/esm/doc.md +149 -147
- package/esm/error.js +1 -1
- package/esm/evalutor.d.ts +158 -147
- package/esm/evalutor.js +159 -148
- package/esm/evalutorForAsync.js +1 -1
- package/esm/filter.js +1 -1
- package/esm/function.js +1 -1
- package/esm/index.js +1 -1
- package/esm/lexer.js +2 -2
- package/esm/parser.js +1 -1
- package/lib/doc.js +99 -99
- package/lib/doc.md +149 -147
- package/lib/error.js +1 -1
- package/lib/evalutor.d.ts +158 -147
- package/lib/evalutor.js +159 -148
- package/lib/evalutorForAsync.js +1 -1
- package/lib/filter.js +1 -1
- package/lib/function.js +1 -1
- package/lib/index.js +1 -1
- package/lib/lexer.js +2 -2
- package/lib/parser.js +1 -1
- package/package.json +7 -2
package/lib/doc.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* amis-formula v3.
|
|
2
|
+
* amis-formula v3.2.0
|
|
3
3
|
* Copyright 2021-2023 fex
|
|
4
4
|
*/
|
|
5
5
|
|
|
@@ -13,13 +13,13 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
13
13
|
var doc = [
|
|
14
14
|
{
|
|
15
15
|
name: "IF",
|
|
16
|
-
description: "
|
|
16
|
+
description: "如果满足条件condition,则返回consequent,否则返回alternate,支持多层嵌套IF函数。\n\n等价于直接用JS表达式如:condition ? consequent : alternate。",
|
|
17
17
|
example: "IF(condition, consequent, alternate)",
|
|
18
18
|
params: [
|
|
19
19
|
{
|
|
20
20
|
type: "expression",
|
|
21
21
|
name: "condition",
|
|
22
|
-
description: "
|
|
22
|
+
description: "条件表达式。例如:语文成绩>80"
|
|
23
23
|
},
|
|
24
24
|
{
|
|
25
25
|
type: "any",
|
|
@@ -40,13 +40,13 @@ var doc = [
|
|
|
40
40
|
},
|
|
41
41
|
{
|
|
42
42
|
name: "AND",
|
|
43
|
-
description: "条件全部符合,返回 true,否则返回 false
|
|
43
|
+
description: "条件全部符合,返回 true,否则返回 false。\n\n示例:AND(语文成绩>80, 数学成绩>80),\n\n语文成绩和数学成绩都大于 80,则返回 true,否则返回 false,\n\n等价于直接用JS表达式如:语文成绩>80 && 数学成绩>80。",
|
|
44
44
|
example: "AND(expression1, expression2, ...expressionN)",
|
|
45
45
|
params: [
|
|
46
46
|
{
|
|
47
47
|
type: "...expression",
|
|
48
48
|
name: "conditions",
|
|
49
|
-
description: "
|
|
49
|
+
description: "条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80"
|
|
50
50
|
}
|
|
51
51
|
],
|
|
52
52
|
returns: {
|
|
@@ -57,13 +57,13 @@ var doc = [
|
|
|
57
57
|
},
|
|
58
58
|
{
|
|
59
59
|
name: "OR",
|
|
60
|
-
description: "条件任意一个满足条件,返回 true,否则返回 false
|
|
60
|
+
description: "条件任意一个满足条件,返回 true,否则返回 false。\n\n示例:OR(语文成绩>80, 数学成绩>80),\n\n语文成绩和数学成绩任意一个大于 80,则返回 true,否则返回 false,\n\n等价于直接用JS表达式如:语文成绩>80 || 数学成绩>80。",
|
|
61
61
|
example: "OR(expression1, expression2, ...expressionN)",
|
|
62
62
|
params: [
|
|
63
63
|
{
|
|
64
64
|
type: "...expression",
|
|
65
65
|
name: "conditions",
|
|
66
|
-
description: "
|
|
66
|
+
description: "条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80"
|
|
67
67
|
}
|
|
68
68
|
],
|
|
69
69
|
returns: {
|
|
@@ -74,18 +74,13 @@ var doc = [
|
|
|
74
74
|
},
|
|
75
75
|
{
|
|
76
76
|
name: "XOR",
|
|
77
|
-
description: "
|
|
78
|
-
example: "XOR(condition1, condition2)",
|
|
77
|
+
description: "异或处理,多个表达式组中存在奇数个真时认为真。\n\n示例:XOR(语文成绩 > 80, 数学成绩 > 80, 英语成绩 > 80)\n\n三门成绩中有一门或者三门大于 80,则返回 true,否则返回 false。",
|
|
78
|
+
example: "XOR(condition1, condition2, ...expressionN)",
|
|
79
79
|
params: [
|
|
80
80
|
{
|
|
81
|
-
type: "expression",
|
|
82
|
-
name: "
|
|
83
|
-
description: "
|
|
84
|
-
},
|
|
85
|
-
{
|
|
86
|
-
type: "expression",
|
|
87
|
-
name: "condition2",
|
|
88
|
-
description: "条件表达式2"
|
|
81
|
+
type: "...expression",
|
|
82
|
+
name: "condition",
|
|
83
|
+
description: "条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80"
|
|
89
84
|
}
|
|
90
85
|
],
|
|
91
86
|
returns: {
|
|
@@ -96,13 +91,18 @@ var doc = [
|
|
|
96
91
|
},
|
|
97
92
|
{
|
|
98
93
|
name: "IFS",
|
|
99
|
-
description: "判断函数集合,相当于多个 else if 合并成一个。\n\n示例:IFS(语文成绩 > 80, \"优秀\", 语文成绩 > 60, \"良\", \"继续努力\")
|
|
94
|
+
description: "判断函数集合,相当于多个 else if 合并成一个。\n\n示例:IFS(语文成绩 > 80, \"优秀\", 语文成绩 > 60, \"良\", \"继续努力\"),\n\n如果语文成绩大于 80,则返回优秀,否则判断大于 60 分,则返回良,否则返回继续努力。",
|
|
100
95
|
example: "IFS(condition1, result1, condition2, result2,...conditionN, resultN)",
|
|
101
96
|
params: [
|
|
97
|
+
{
|
|
98
|
+
type: "...expression",
|
|
99
|
+
name: "condition",
|
|
100
|
+
description: "条件表达式"
|
|
101
|
+
},
|
|
102
102
|
{
|
|
103
103
|
type: "...any",
|
|
104
|
-
name: "
|
|
105
|
-
description: "
|
|
104
|
+
name: "result",
|
|
105
|
+
description: "返回值"
|
|
106
106
|
}
|
|
107
107
|
],
|
|
108
108
|
returns: {
|
|
@@ -113,7 +113,7 @@ var doc = [
|
|
|
113
113
|
},
|
|
114
114
|
{
|
|
115
115
|
name: "ABS",
|
|
116
|
-
description: "
|
|
116
|
+
description: "返回传入数字的绝对值。",
|
|
117
117
|
example: "ABS(num)",
|
|
118
118
|
params: [
|
|
119
119
|
{
|
|
@@ -130,7 +130,7 @@ var doc = [
|
|
|
130
130
|
},
|
|
131
131
|
{
|
|
132
132
|
name: "MAX",
|
|
133
|
-
description: "
|
|
133
|
+
description: "获取最大值,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
134
134
|
example: "MAX(num1, num2, ...numN)",
|
|
135
135
|
params: [
|
|
136
136
|
{
|
|
@@ -147,7 +147,7 @@ var doc = [
|
|
|
147
147
|
},
|
|
148
148
|
{
|
|
149
149
|
name: "MIN",
|
|
150
|
-
description: "
|
|
150
|
+
description: "获取最小值,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
151
151
|
example: "MIN(num1, num2, ...numN)",
|
|
152
152
|
params: [
|
|
153
153
|
{
|
|
@@ -164,7 +164,7 @@ var doc = [
|
|
|
164
164
|
},
|
|
165
165
|
{
|
|
166
166
|
name: "SUM",
|
|
167
|
-
description: "
|
|
167
|
+
description: "求和,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
168
168
|
example: "SUM(num1, num2, ...numN)",
|
|
169
169
|
params: [
|
|
170
170
|
{
|
|
@@ -181,7 +181,7 @@ var doc = [
|
|
|
181
181
|
},
|
|
182
182
|
{
|
|
183
183
|
name: "INT",
|
|
184
|
-
description: "
|
|
184
|
+
description: "将数值向下取整为最接近的整数。",
|
|
185
185
|
example: "INT(num)",
|
|
186
186
|
params: [
|
|
187
187
|
{
|
|
@@ -198,7 +198,7 @@ var doc = [
|
|
|
198
198
|
},
|
|
199
199
|
{
|
|
200
200
|
name: "MOD",
|
|
201
|
-
description: "返回两数相除的余数,参数 number 是被除数,divisor
|
|
201
|
+
description: "返回两数相除的余数,参数 number 是被除数,divisor 是除数。",
|
|
202
202
|
example: "MOD(num, divisor)",
|
|
203
203
|
params: [
|
|
204
204
|
{
|
|
@@ -220,7 +220,7 @@ var doc = [
|
|
|
220
220
|
},
|
|
221
221
|
{
|
|
222
222
|
name: "PI",
|
|
223
|
-
description: "圆周率 3.1415
|
|
223
|
+
description: "圆周率 3.1415...。",
|
|
224
224
|
example: "PI()",
|
|
225
225
|
params: [],
|
|
226
226
|
returns: {
|
|
@@ -242,7 +242,7 @@ var doc = [
|
|
|
242
242
|
{
|
|
243
243
|
type: "number",
|
|
244
244
|
name: "numDigits",
|
|
245
|
-
description: "
|
|
245
|
+
description: "小数位数,默认为2"
|
|
246
246
|
}
|
|
247
247
|
],
|
|
248
248
|
returns: {
|
|
@@ -264,7 +264,7 @@ var doc = [
|
|
|
264
264
|
{
|
|
265
265
|
type: "number",
|
|
266
266
|
name: "numDigits",
|
|
267
|
-
description: "
|
|
267
|
+
description: "小数位数,默认为2"
|
|
268
268
|
}
|
|
269
269
|
],
|
|
270
270
|
returns: {
|
|
@@ -286,7 +286,7 @@ var doc = [
|
|
|
286
286
|
{
|
|
287
287
|
type: "number",
|
|
288
288
|
name: "numDigits",
|
|
289
|
-
description: "
|
|
289
|
+
description: "小数位数,默认为2"
|
|
290
290
|
}
|
|
291
291
|
],
|
|
292
292
|
returns: {
|
|
@@ -314,7 +314,7 @@ var doc = [
|
|
|
314
314
|
},
|
|
315
315
|
{
|
|
316
316
|
name: "AVG",
|
|
317
|
-
description: "
|
|
317
|
+
description: "返回所有参数的平均值,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
318
318
|
example: "AVG(num1, num2, ...numN)",
|
|
319
319
|
params: [
|
|
320
320
|
{
|
|
@@ -331,7 +331,7 @@ var doc = [
|
|
|
331
331
|
},
|
|
332
332
|
{
|
|
333
333
|
name: "DEVSQ",
|
|
334
|
-
description: "
|
|
334
|
+
description: "返回数据点与数据均值点之差(数据偏差)的平方和,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
335
335
|
example: "DEVSQ(num1, num2, ...numN)",
|
|
336
336
|
params: [
|
|
337
337
|
{
|
|
@@ -348,7 +348,7 @@ var doc = [
|
|
|
348
348
|
},
|
|
349
349
|
{
|
|
350
350
|
name: "AVEDEV",
|
|
351
|
-
description: "
|
|
351
|
+
description: "数据点到其算术平均值的绝对偏差的平均值。",
|
|
352
352
|
example: "AVEDEV(num1, num2, ...numN)",
|
|
353
353
|
params: [
|
|
354
354
|
{
|
|
@@ -365,7 +365,7 @@ var doc = [
|
|
|
365
365
|
},
|
|
366
366
|
{
|
|
367
367
|
name: "HARMEAN",
|
|
368
|
-
description: "
|
|
368
|
+
description: "数据点的调和平均值,如果只有一个参数且是数组,则计算这个数组内的值。",
|
|
369
369
|
example: "HARMEAN(num1, num2, ...numN)",
|
|
370
370
|
params: [
|
|
371
371
|
{
|
|
@@ -382,7 +382,7 @@ var doc = [
|
|
|
382
382
|
},
|
|
383
383
|
{
|
|
384
384
|
name: "LARGE",
|
|
385
|
-
description: "数据集中第 k
|
|
385
|
+
description: "数据集中第 k 个最大值。",
|
|
386
386
|
example: "LARGE(array, k)",
|
|
387
387
|
params: [
|
|
388
388
|
{
|
|
@@ -404,7 +404,7 @@ var doc = [
|
|
|
404
404
|
},
|
|
405
405
|
{
|
|
406
406
|
name: "UPPERMONEY",
|
|
407
|
-
description: "
|
|
407
|
+
description: "将数值转为中文大写金额。",
|
|
408
408
|
example: "UPPERMONEY(num)",
|
|
409
409
|
params: [
|
|
410
410
|
{
|
|
@@ -421,7 +421,7 @@ var doc = [
|
|
|
421
421
|
},
|
|
422
422
|
{
|
|
423
423
|
name: "RAND",
|
|
424
|
-
description: "返回大于等于 0 且小于 1 的均匀分布随机实数。每一次触发计算都会变化。\n\n示例:`RAND()*100
|
|
424
|
+
description: "返回大于等于 0 且小于 1 的均匀分布随机实数。每一次触发计算都会变化。\n\n示例:`RAND()*100`,\n\n返回 0-100 之间的随机数。",
|
|
425
425
|
example: "RAND()",
|
|
426
426
|
params: [],
|
|
427
427
|
returns: {
|
|
@@ -432,7 +432,7 @@ var doc = [
|
|
|
432
432
|
},
|
|
433
433
|
{
|
|
434
434
|
name: "LAST",
|
|
435
|
-
description: "
|
|
435
|
+
description: "取数据最后一个。",
|
|
436
436
|
example: "LAST(array)",
|
|
437
437
|
params: [
|
|
438
438
|
{
|
|
@@ -493,7 +493,7 @@ var doc = [
|
|
|
493
493
|
},
|
|
494
494
|
{
|
|
495
495
|
name: "LEN",
|
|
496
|
-
description: "
|
|
496
|
+
description: "计算文本的长度。",
|
|
497
497
|
example: "LEN(text)",
|
|
498
498
|
params: [
|
|
499
499
|
{
|
|
@@ -510,7 +510,7 @@ var doc = [
|
|
|
510
510
|
},
|
|
511
511
|
{
|
|
512
512
|
name: "LENGTH",
|
|
513
|
-
description: "
|
|
513
|
+
description: "计算文本集合中所有文本的长度。",
|
|
514
514
|
example: "LENGTH(textArr)",
|
|
515
515
|
params: [
|
|
516
516
|
{
|
|
@@ -527,7 +527,7 @@ var doc = [
|
|
|
527
527
|
},
|
|
528
528
|
{
|
|
529
529
|
name: "ISEMPTY",
|
|
530
|
-
description: "
|
|
530
|
+
description: "判断文本是否为空。",
|
|
531
531
|
example: "ISEMPTY(text)",
|
|
532
532
|
params: [
|
|
533
533
|
{
|
|
@@ -544,7 +544,7 @@ var doc = [
|
|
|
544
544
|
},
|
|
545
545
|
{
|
|
546
546
|
name: "CONCATENATE",
|
|
547
|
-
description: "
|
|
547
|
+
description: "将多个传入值连接成文本。",
|
|
548
548
|
example: "CONCATENATE(text1, text2, ...textN)",
|
|
549
549
|
params: [
|
|
550
550
|
{
|
|
@@ -561,7 +561,7 @@ var doc = [
|
|
|
561
561
|
},
|
|
562
562
|
{
|
|
563
563
|
name: "CHAR",
|
|
564
|
-
description: "返回计算机字符集的数字代码所对应的字符。\n\n
|
|
564
|
+
description: "返回计算机字符集的数字代码所对应的字符。\n\n示例:`CHAR(97)` 等价于 \"a\"。",
|
|
565
565
|
example: "CHAR(code)",
|
|
566
566
|
params: [
|
|
567
567
|
{
|
|
@@ -578,7 +578,7 @@ var doc = [
|
|
|
578
578
|
},
|
|
579
579
|
{
|
|
580
580
|
name: "LOWER",
|
|
581
|
-
description: "
|
|
581
|
+
description: "将传入文本转成小写。",
|
|
582
582
|
example: "LOWER(text)",
|
|
583
583
|
params: [
|
|
584
584
|
{
|
|
@@ -595,7 +595,7 @@ var doc = [
|
|
|
595
595
|
},
|
|
596
596
|
{
|
|
597
597
|
name: "UPPER",
|
|
598
|
-
description: "
|
|
598
|
+
description: "将传入文本转成大写。",
|
|
599
599
|
example: "UPPER(text)",
|
|
600
600
|
params: [
|
|
601
601
|
{
|
|
@@ -612,7 +612,7 @@ var doc = [
|
|
|
612
612
|
},
|
|
613
613
|
{
|
|
614
614
|
name: "UPPERFIRST",
|
|
615
|
-
description: "
|
|
615
|
+
description: "将传入文本首字母转成大写。",
|
|
616
616
|
example: "UPPERFIRST(text)",
|
|
617
617
|
params: [
|
|
618
618
|
{
|
|
@@ -629,7 +629,7 @@ var doc = [
|
|
|
629
629
|
},
|
|
630
630
|
{
|
|
631
631
|
name: "PADSTART",
|
|
632
|
-
description: "
|
|
632
|
+
description: "向前补齐文本长度。\n\n示例 `PADSTART(\"6\", 2, \"0\")`,\n\n返回 `06`。",
|
|
633
633
|
example: "PADSTART(text)",
|
|
634
634
|
params: [
|
|
635
635
|
{
|
|
@@ -656,7 +656,7 @@ var doc = [
|
|
|
656
656
|
},
|
|
657
657
|
{
|
|
658
658
|
name: "CAPITALIZE",
|
|
659
|
-
description: "
|
|
659
|
+
description: "将文本转成标题。\n\n示例 `CAPITALIZE(\"star\")`,\n\n返回 `Star`。",
|
|
660
660
|
example: "CAPITALIZE(text)",
|
|
661
661
|
params: [
|
|
662
662
|
{
|
|
@@ -673,7 +673,7 @@ var doc = [
|
|
|
673
673
|
},
|
|
674
674
|
{
|
|
675
675
|
name: "ESCAPE",
|
|
676
|
-
description: "对文本进行 HTML
|
|
676
|
+
description: "对文本进行 HTML 转义。\n\n示例 `ESCAPE(\"<star>&\")`,\n\n返回 `<start>&`。",
|
|
677
677
|
example: "ESCAPE(text)",
|
|
678
678
|
params: [
|
|
679
679
|
{
|
|
@@ -690,7 +690,7 @@ var doc = [
|
|
|
690
690
|
},
|
|
691
691
|
{
|
|
692
692
|
name: "TRUNCATE",
|
|
693
|
-
description: "
|
|
693
|
+
description: "对文本长度进行截断。\n\n示例 `TRUNCATE(\"amis.baidu.com\", 6)`,\n\n返回 `amis...`。",
|
|
694
694
|
example: "TRUNCATE(text, 6)",
|
|
695
695
|
params: [
|
|
696
696
|
{
|
|
@@ -712,7 +712,7 @@ var doc = [
|
|
|
712
712
|
},
|
|
713
713
|
{
|
|
714
714
|
name: "BEFORELAST",
|
|
715
|
-
description: "
|
|
715
|
+
description: "取在某个分隔符之前的所有字符串。",
|
|
716
716
|
example: "BEFORELAST(text, '.')",
|
|
717
717
|
params: [
|
|
718
718
|
{
|
|
@@ -734,7 +734,7 @@ var doc = [
|
|
|
734
734
|
},
|
|
735
735
|
{
|
|
736
736
|
name: "SPLIT",
|
|
737
|
-
description: "
|
|
737
|
+
description: "将文本根据指定片段分割成数组。\n\n示例:`SPLIT(\"a,b,c\", \",\")`,\n\n返回 `[\"a\", \"b\", \"c\"]`。",
|
|
738
738
|
example: "SPLIT(text, ',')",
|
|
739
739
|
params: [
|
|
740
740
|
{
|
|
@@ -756,7 +756,7 @@ var doc = [
|
|
|
756
756
|
},
|
|
757
757
|
{
|
|
758
758
|
name: "TRIM",
|
|
759
|
-
description: "
|
|
759
|
+
description: "将文本去除前后空格。",
|
|
760
760
|
example: "TRIM(text)",
|
|
761
761
|
params: [
|
|
762
762
|
{
|
|
@@ -773,7 +773,7 @@ var doc = [
|
|
|
773
773
|
},
|
|
774
774
|
{
|
|
775
775
|
name: "STRIPTAG",
|
|
776
|
-
description: "去除文本中的 HTML
|
|
776
|
+
description: "去除文本中的 HTML 标签。\n\n示例:`STRIPTAG(\"<b>amis</b>\")`,\n\n返回:`amis`。",
|
|
777
777
|
example: "STRIPTAG(text)",
|
|
778
778
|
params: [
|
|
779
779
|
{
|
|
@@ -790,7 +790,7 @@ var doc = [
|
|
|
790
790
|
},
|
|
791
791
|
{
|
|
792
792
|
name: "LINEBREAK",
|
|
793
|
-
description: "将字符串中的换行转成 HTML `<br
|
|
793
|
+
description: "将字符串中的换行转成 HTML `<br>`,用于简单换行的场景。\n\n示例:`LINEBREAK(\"\\n\")`,\n\n返回:`<br/>`。",
|
|
794
794
|
example: "LINEBREAK(text)",
|
|
795
795
|
params: [
|
|
796
796
|
{
|
|
@@ -807,7 +807,7 @@ var doc = [
|
|
|
807
807
|
},
|
|
808
808
|
{
|
|
809
809
|
name: "STARTSWITH",
|
|
810
|
-
description: "判断字符串(text)是否以特定字符串(startString)开始,是则返回
|
|
810
|
+
description: "判断字符串(text)是否以特定字符串(startString)开始,是则返回 true,否则返回 false。",
|
|
811
811
|
example: "STARTSWITH(text, '片段')",
|
|
812
812
|
params: [
|
|
813
813
|
{
|
|
@@ -829,7 +829,7 @@ var doc = [
|
|
|
829
829
|
},
|
|
830
830
|
{
|
|
831
831
|
name: "ENDSWITH",
|
|
832
|
-
description: "判断字符串(text)是否以特定字符串(endString)结束,是则返回
|
|
832
|
+
description: "判断字符串(text)是否以特定字符串(endString)结束,是则返回 true,否则返回 false。",
|
|
833
833
|
example: "ENDSWITH(text, '片段')",
|
|
834
834
|
params: [
|
|
835
835
|
{
|
|
@@ -851,7 +851,7 @@ var doc = [
|
|
|
851
851
|
},
|
|
852
852
|
{
|
|
853
853
|
name: "CONTAINS",
|
|
854
|
-
description: "判断参数 1 中的文本是否包含参数 2
|
|
854
|
+
description: "判断参数 1 中的文本是否包含参数 2 中的文本,是则返回 true,否则返回 false。",
|
|
855
855
|
example: "CONTAINS(text, searchText)",
|
|
856
856
|
params: [
|
|
857
857
|
{
|
|
@@ -900,7 +900,7 @@ var doc = [
|
|
|
900
900
|
},
|
|
901
901
|
{
|
|
902
902
|
name: "SEARCH",
|
|
903
|
-
description: "
|
|
903
|
+
description: "对文本进行搜索,返回命中的位置。",
|
|
904
904
|
example: "SEARCH(text, search, 0)",
|
|
905
905
|
params: [
|
|
906
906
|
{
|
|
@@ -927,7 +927,7 @@ var doc = [
|
|
|
927
927
|
},
|
|
928
928
|
{
|
|
929
929
|
name: "MID",
|
|
930
|
-
description: "
|
|
930
|
+
description: "返回文本字符串中从指定位置开始的特定数目的字符。",
|
|
931
931
|
example: "MID(text, from, len)",
|
|
932
932
|
params: [
|
|
933
933
|
{
|
|
@@ -954,7 +954,7 @@ var doc = [
|
|
|
954
954
|
},
|
|
955
955
|
{
|
|
956
956
|
name: "BASENAME",
|
|
957
|
-
description: "
|
|
957
|
+
description: "返回路径中的文件名。\n\n示例:`/home/amis/a.json`,\n\n返回:a.json`。",
|
|
958
958
|
example: "BASENAME(text)",
|
|
959
959
|
params: [
|
|
960
960
|
{
|
|
@@ -971,7 +971,7 @@ var doc = [
|
|
|
971
971
|
},
|
|
972
972
|
{
|
|
973
973
|
name: "DATE",
|
|
974
|
-
description: "创建日期对象,可以通过特定格式的字符串,或者数值。\n\n需要注意的是,其中月份的数值是从0
|
|
974
|
+
description: "创建日期对象,可以通过特定格式的字符串,或者数值。\n\n需要注意的是,其中月份的数值是从0开始的,\n即如果是12月份,你应该传入数值11。",
|
|
975
975
|
example: "DATE('2021-12-06 08:20:00')",
|
|
976
976
|
params: [],
|
|
977
977
|
returns: {
|
|
@@ -982,8 +982,8 @@ var doc = [
|
|
|
982
982
|
},
|
|
983
983
|
{
|
|
984
984
|
name: "TIMESTAMP",
|
|
985
|
-
description: "
|
|
986
|
-
example: "TIMESTAMP(date,
|
|
985
|
+
description: "返回时间的时间戳。",
|
|
986
|
+
example: "TIMESTAMP(date[, format = \"X\"])",
|
|
987
987
|
params: [
|
|
988
988
|
{
|
|
989
989
|
type: "date",
|
|
@@ -1004,7 +1004,7 @@ var doc = [
|
|
|
1004
1004
|
},
|
|
1005
1005
|
{
|
|
1006
1006
|
name: "TODAY",
|
|
1007
|
-
description: "
|
|
1007
|
+
description: "返回今天的日期。",
|
|
1008
1008
|
example: "TODAY()",
|
|
1009
1009
|
params: [],
|
|
1010
1010
|
returns: {
|
|
@@ -1026,7 +1026,7 @@ var doc = [
|
|
|
1026
1026
|
},
|
|
1027
1027
|
{
|
|
1028
1028
|
name: "WEEKDAY",
|
|
1029
|
-
description: "
|
|
1029
|
+
description: "获取日期的星期几。\n\n示例\n\nWEEKDAY('2023-02-27') 得到 1。",
|
|
1030
1030
|
example: "WEEKDAY(date)",
|
|
1031
1031
|
params: [
|
|
1032
1032
|
{
|
|
@@ -1048,7 +1048,7 @@ var doc = [
|
|
|
1048
1048
|
},
|
|
1049
1049
|
{
|
|
1050
1050
|
name: "WEEK",
|
|
1051
|
-
description: "
|
|
1051
|
+
description: "获取年份的星期,即第几周。\n\n示例\n\nWEEK('2023-03-05') 得到 10。",
|
|
1052
1052
|
example: "WEEK(date)",
|
|
1053
1053
|
params: [
|
|
1054
1054
|
{
|
|
@@ -1070,7 +1070,7 @@ var doc = [
|
|
|
1070
1070
|
},
|
|
1071
1071
|
{
|
|
1072
1072
|
name: "DATETOSTR",
|
|
1073
|
-
description: "
|
|
1073
|
+
description: "对日期、日期字符串、时间戳进行格式化。\n\n示例\n\nDATETOSTR('12/25/2022', 'YYYY-MM-DD') 得到 '2022.12.25',\nDATETOSTR(1676563200, 'YYYY.MM.DD') 得到 '2023.02.17',\nDATETOSTR(1676563200000, 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00',\nDATETOSTR(DATE('2021-12-21'), 'YYYY.MM.DD hh:mm:ss') 得到 '2021.12.21 08:00:00'。",
|
|
1074
1074
|
example: "DATETOSTR(date, 'YYYY-MM-DD')",
|
|
1075
1075
|
params: [
|
|
1076
1076
|
{
|
|
@@ -1092,7 +1092,7 @@ var doc = [
|
|
|
1092
1092
|
},
|
|
1093
1093
|
{
|
|
1094
1094
|
name: "DATERANGESPLIT",
|
|
1095
|
-
description: "
|
|
1095
|
+
description: "获取日期范围字符串中的开始时间、结束时间。\n\n示例:\n\nDATERANGESPLIT('1676563200, 1676735999') 得到 [1676563200, 1676735999],\nDATERANGESPLIT('1676563200, 1676735999', undefined , 'YYYY.MM.DD hh:mm:ss') 得到 [2023.02.17 12:00:00, 2023.02.18 11:59:59],\nDATERANGESPLIT('1676563200, 1676735999', 0 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00',\nDATERANGESPLIT('1676563200, 1676735999', 'start' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00',\nDATERANGESPLIT('1676563200, 1676735999', 1 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59',\nDATERANGESPLIT('1676563200, 1676735999', 'end' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59'。",
|
|
1096
1096
|
example: "DATERANGESPLIT(date, 'YYYY-MM-DD')",
|
|
1097
1097
|
params: [
|
|
1098
1098
|
{
|
|
@@ -1124,7 +1124,7 @@ var doc = [
|
|
|
1124
1124
|
},
|
|
1125
1125
|
{
|
|
1126
1126
|
name: "STARTOF",
|
|
1127
|
-
description: "
|
|
1127
|
+
description: "返回日期的指定范围的开端。",
|
|
1128
1128
|
example: "STARTOF(date[unit = \"day\"])",
|
|
1129
1129
|
params: [
|
|
1130
1130
|
{
|
|
@@ -1151,7 +1151,7 @@ var doc = [
|
|
|
1151
1151
|
},
|
|
1152
1152
|
{
|
|
1153
1153
|
name: "ENDOF",
|
|
1154
|
-
description: "
|
|
1154
|
+
description: "返回日期的指定范围的末尾。",
|
|
1155
1155
|
example: "ENDOF(date[unit = \"day\"])",
|
|
1156
1156
|
params: [
|
|
1157
1157
|
{
|
|
@@ -1178,7 +1178,7 @@ var doc = [
|
|
|
1178
1178
|
},
|
|
1179
1179
|
{
|
|
1180
1180
|
name: "YEAR",
|
|
1181
|
-
description: "
|
|
1181
|
+
description: "返回日期的年份。",
|
|
1182
1182
|
example: "YEAR(date)",
|
|
1183
1183
|
params: [
|
|
1184
1184
|
{
|
|
@@ -1212,7 +1212,7 @@ var doc = [
|
|
|
1212
1212
|
},
|
|
1213
1213
|
{
|
|
1214
1214
|
name: "DAY",
|
|
1215
|
-
description: "
|
|
1215
|
+
description: "返回日期的天。",
|
|
1216
1216
|
example: "DAY(date)",
|
|
1217
1217
|
params: [
|
|
1218
1218
|
{
|
|
@@ -1229,7 +1229,7 @@ var doc = [
|
|
|
1229
1229
|
},
|
|
1230
1230
|
{
|
|
1231
1231
|
name: "HOUR",
|
|
1232
|
-
description: "
|
|
1232
|
+
description: "返回日期的小时。",
|
|
1233
1233
|
example: "HOUR(date)",
|
|
1234
1234
|
params: [
|
|
1235
1235
|
{
|
|
@@ -1246,7 +1246,7 @@ var doc = [
|
|
|
1246
1246
|
},
|
|
1247
1247
|
{
|
|
1248
1248
|
name: "MINUTE",
|
|
1249
|
-
description: "
|
|
1249
|
+
description: "返回日期的分。",
|
|
1250
1250
|
example: "MINUTE(date)",
|
|
1251
1251
|
params: [
|
|
1252
1252
|
{
|
|
@@ -1263,7 +1263,7 @@ var doc = [
|
|
|
1263
1263
|
},
|
|
1264
1264
|
{
|
|
1265
1265
|
name: "SECOND",
|
|
1266
|
-
description: "
|
|
1266
|
+
description: "返回日期的秒。",
|
|
1267
1267
|
example: "SECOND(date)",
|
|
1268
1268
|
params: [
|
|
1269
1269
|
{
|
|
@@ -1280,7 +1280,7 @@ var doc = [
|
|
|
1280
1280
|
},
|
|
1281
1281
|
{
|
|
1282
1282
|
name: "YEARS",
|
|
1283
|
-
description: "
|
|
1283
|
+
description: "返回两个日期相差多少年。",
|
|
1284
1284
|
example: "YEARS(endDate, startDate)",
|
|
1285
1285
|
params: [
|
|
1286
1286
|
{
|
|
@@ -1302,7 +1302,7 @@ var doc = [
|
|
|
1302
1302
|
},
|
|
1303
1303
|
{
|
|
1304
1304
|
name: "MINUTES",
|
|
1305
|
-
description: "
|
|
1305
|
+
description: "返回两个日期相差多少分钟。",
|
|
1306
1306
|
example: "MINUTES(endDate, startDate)",
|
|
1307
1307
|
params: [
|
|
1308
1308
|
{
|
|
@@ -1324,7 +1324,7 @@ var doc = [
|
|
|
1324
1324
|
},
|
|
1325
1325
|
{
|
|
1326
1326
|
name: "DAYS",
|
|
1327
|
-
description: "
|
|
1327
|
+
description: "返回两个日期相差多少天。",
|
|
1328
1328
|
example: "DAYS(endDate, startDate)",
|
|
1329
1329
|
params: [
|
|
1330
1330
|
{
|
|
@@ -1346,7 +1346,7 @@ var doc = [
|
|
|
1346
1346
|
},
|
|
1347
1347
|
{
|
|
1348
1348
|
name: "HOURS",
|
|
1349
|
-
description: "
|
|
1349
|
+
description: "返回两个日期相差多少小时。",
|
|
1350
1350
|
example: "HOURS(endDate, startDate)",
|
|
1351
1351
|
params: [
|
|
1352
1352
|
{
|
|
@@ -1368,7 +1368,7 @@ var doc = [
|
|
|
1368
1368
|
},
|
|
1369
1369
|
{
|
|
1370
1370
|
name: "DATEMODIFY",
|
|
1371
|
-
description: "
|
|
1371
|
+
description: "修改日期,对日期进行加减天、月份、年等操作。\n\n示例:\n\nDATEMODIFY(A, -2, 'month'),\n\n对日期 A 进行往前减2月的操作。",
|
|
1372
1372
|
example: "DATEMODIFY(date, 2, 'days')",
|
|
1373
1373
|
params: [
|
|
1374
1374
|
{
|
|
@@ -1417,7 +1417,7 @@ var doc = [
|
|
|
1417
1417
|
},
|
|
1418
1418
|
{
|
|
1419
1419
|
name: "ISBEFORE",
|
|
1420
|
-
description: "
|
|
1420
|
+
description: "判断两个日期,是否第一个日期在第二个日期的前面,是则返回 true,否则返回 false。",
|
|
1421
1421
|
example: "ISBEFORE(a, b)",
|
|
1422
1422
|
params: [
|
|
1423
1423
|
{
|
|
@@ -1444,7 +1444,7 @@ var doc = [
|
|
|
1444
1444
|
},
|
|
1445
1445
|
{
|
|
1446
1446
|
name: "ISAFTER",
|
|
1447
|
-
description: "
|
|
1447
|
+
description: "判断两个日期,是否第一个日期在第二个日期的后面,是则返回 true,否则返回 false。",
|
|
1448
1448
|
example: "ISAFTER(a, b)",
|
|
1449
1449
|
params: [
|
|
1450
1450
|
{
|
|
@@ -1471,7 +1471,7 @@ var doc = [
|
|
|
1471
1471
|
},
|
|
1472
1472
|
{
|
|
1473
1473
|
name: "BETWEENRANGE",
|
|
1474
|
-
description: "
|
|
1474
|
+
description: "判断日期是否在指定范围内,是则返回 true,否则返回 false。\n\n示例:BETWEENRANGE('2021/12/6', ['2021/12/5','2021/12/7'])。",
|
|
1475
1475
|
example: "BETWEENRANGE(date, [start, end])",
|
|
1476
1476
|
params: [
|
|
1477
1477
|
{
|
|
@@ -1503,7 +1503,7 @@ var doc = [
|
|
|
1503
1503
|
},
|
|
1504
1504
|
{
|
|
1505
1505
|
name: "ISSAMEORBEFORE",
|
|
1506
|
-
description: "
|
|
1506
|
+
description: "判断两个日期,是否第一个日期在第二个日期的前面或者相等,是则返回 true,否则返回 false。",
|
|
1507
1507
|
example: "ISSAMEORBEFORE(a, b)",
|
|
1508
1508
|
params: [
|
|
1509
1509
|
{
|
|
@@ -1530,7 +1530,7 @@ var doc = [
|
|
|
1530
1530
|
},
|
|
1531
1531
|
{
|
|
1532
1532
|
name: "ISSAMEORAFTER",
|
|
1533
|
-
description: "
|
|
1533
|
+
description: "判断两个日期,是否第一个日期在第二个日期的后面或者相等,是则返回 true,否则返回 false。",
|
|
1534
1534
|
example: "ISSAMEORAFTER(a, b)",
|
|
1535
1535
|
params: [
|
|
1536
1536
|
{
|
|
@@ -1557,7 +1557,7 @@ var doc = [
|
|
|
1557
1557
|
},
|
|
1558
1558
|
{
|
|
1559
1559
|
name: "COUNT",
|
|
1560
|
-
description: "
|
|
1560
|
+
description: "返回数组的长度。",
|
|
1561
1561
|
example: "COUNT(arr)",
|
|
1562
1562
|
params: [
|
|
1563
1563
|
{
|
|
@@ -1618,7 +1618,7 @@ var doc = [
|
|
|
1618
1618
|
},
|
|
1619
1619
|
{
|
|
1620
1620
|
name: "ARRAYFINDINDEX",
|
|
1621
|
-
description: "数据做数据查找,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n找出第二个箭头函数返回为 true 的成员的索引。\n\n示例:\n\nARRAYFINDINDEX([0, 2, false], item => item === 2) 得到 1",
|
|
1621
|
+
description: "数据做数据查找,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n找出第二个箭头函数返回为 true 的成员的索引。\n\n示例:\n\nARRAYFINDINDEX([0, 2, false], item => item === 2) 得到 1。",
|
|
1622
1622
|
example: "ARRAYFINDINDEX(arr, item => item === 2)",
|
|
1623
1623
|
params: [
|
|
1624
1624
|
{
|
|
@@ -1640,7 +1640,7 @@ var doc = [
|
|
|
1640
1640
|
},
|
|
1641
1641
|
{
|
|
1642
1642
|
name: "ARRAYFIND",
|
|
1643
|
-
description: "数据做数据查找,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n找出第二个箭头函数返回为 true 的成员。\n\n示例:\n\nARRAYFIND([0, 2, false], item => item === 2) 得到 2",
|
|
1643
|
+
description: "数据做数据查找,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n找出第二个箭头函数返回为 true 的成员。\n\n示例:\n\nARRAYFIND([0, 2, false], item => item === 2) 得到 2。",
|
|
1644
1644
|
example: "ARRAYFIND(arr, item => item === 2)",
|
|
1645
1645
|
params: [
|
|
1646
1646
|
{
|
|
@@ -1662,7 +1662,7 @@ var doc = [
|
|
|
1662
1662
|
},
|
|
1663
1663
|
{
|
|
1664
1664
|
name: "ARRAYSOME",
|
|
1665
|
-
description: "数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n判断第二个箭头函数是否存在返回为 true
|
|
1665
|
+
description: "数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n判断第二个箭头函数是否存在返回为 true 的成员,是则返回 true,否则返回 false。\n\n示例:\n\nARRAYSOME([0, 2, false], item => item === 2) 得到 true。",
|
|
1666
1666
|
example: "ARRAYSOME(arr, item => item === 2)",
|
|
1667
1667
|
params: [
|
|
1668
1668
|
{
|
|
@@ -1684,7 +1684,7 @@ var doc = [
|
|
|
1684
1684
|
},
|
|
1685
1685
|
{
|
|
1686
1686
|
name: "ARRAYEVERY",
|
|
1687
|
-
description: "数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n判断第二个箭头函数返回是否都为 true。\n\n示例:\n\nARRAYEVERY([0, 2, false], item => item === 2) 得到 false",
|
|
1687
|
+
description: "数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。\n判断第二个箭头函数返回是否都为 true,是则返回 true,否则返回 false。\n\n示例:\n\nARRAYEVERY([0, 2, false], item => item === 2) 得到 false",
|
|
1688
1688
|
example: "ARRAYEVERY(arr, item => item === 2)",
|
|
1689
1689
|
params: [
|
|
1690
1690
|
{
|
|
@@ -1706,7 +1706,7 @@ var doc = [
|
|
|
1706
1706
|
},
|
|
1707
1707
|
{
|
|
1708
1708
|
name: "ARRAYINCLUDES",
|
|
1709
|
-
description: "
|
|
1709
|
+
description: "判断数据中是否存在指定元素。\n\n示例:\n\nARRAYINCLUDES([0, 2, false], 2) 得到 true。",
|
|
1710
1710
|
example: "ARRAYINCLUDES(arr, 2)",
|
|
1711
1711
|
params: [
|
|
1712
1712
|
{
|
|
@@ -1728,7 +1728,7 @@ var doc = [
|
|
|
1728
1728
|
},
|
|
1729
1729
|
{
|
|
1730
1730
|
name: "COMPACT",
|
|
1731
|
-
description: "数组过滤掉 false、null、0 和 \"\"
|
|
1731
|
+
description: "数组过滤掉 false、null、0 和 \"\"。\n\n示例:\n\nCOMPACT([0, 1, false, 2, '', 3]) 得到 [1, 2, 3]。",
|
|
1732
1732
|
example: "COMPACT(arr)",
|
|
1733
1733
|
params: [
|
|
1734
1734
|
{
|
|
@@ -1745,7 +1745,7 @@ var doc = [
|
|
|
1745
1745
|
},
|
|
1746
1746
|
{
|
|
1747
1747
|
name: "JOIN",
|
|
1748
|
-
description: "
|
|
1748
|
+
description: "数组转成字符串。\n\n示例:\n\nJOIN(['a', 'b', 'c'], '=') 得到 'a=b=c'。",
|
|
1749
1749
|
example: "JOIN(arr, string)",
|
|
1750
1750
|
params: [
|
|
1751
1751
|
{
|
|
@@ -1767,7 +1767,7 @@ var doc = [
|
|
|
1767
1767
|
},
|
|
1768
1768
|
{
|
|
1769
1769
|
name: "CONCAT",
|
|
1770
|
-
description: "
|
|
1770
|
+
description: "数组合并。\n\n示例:\n\nCONCAT(['a', 'b', 'c'], ['1'], ['3']) 得到 ['a', 'b', 'c', '1', '3']。",
|
|
1771
1771
|
example: "CONCAT(['a', 'b', 'c'], ['1'], ['3'])",
|
|
1772
1772
|
params: [
|
|
1773
1773
|
{
|
|
@@ -1784,7 +1784,7 @@ var doc = [
|
|
|
1784
1784
|
},
|
|
1785
1785
|
{
|
|
1786
1786
|
name: "UNIQ",
|
|
1787
|
-
description: "数组去重,第二个参数「field
|
|
1787
|
+
description: "数组去重,第二个参数「field」,可指定根据该字段去重。\n\n示例:\n\nUNIQ([{a: '1'}, {b: '2'}, {a: '1'}], 'id')。",
|
|
1788
1788
|
example: "UNIQ([{a: '1'}, {b: '2'}, {a: '1'}], 'x')",
|
|
1789
1789
|
params: [
|
|
1790
1790
|
{
|
|
@@ -1806,7 +1806,7 @@ var doc = [
|
|
|
1806
1806
|
},
|
|
1807
1807
|
{
|
|
1808
1808
|
name: "ENCODEJSON",
|
|
1809
|
-
description: "将JS对象转换成JSON
|
|
1809
|
+
description: "将JS对象转换成JSON字符串。\n\n示例:\n\nENCODEJSON({name: 'amis'}) 得到 '{\"name\":\"amis\"}'。",
|
|
1810
1810
|
example: "ENCODEJSON({name: 'amis'})",
|
|
1811
1811
|
params: [
|
|
1812
1812
|
{
|
|
@@ -1823,7 +1823,7 @@ var doc = [
|
|
|
1823
1823
|
},
|
|
1824
1824
|
{
|
|
1825
1825
|
name: "DECODEJSON",
|
|
1826
|
-
description: "解析JSON编码数据,返回JS
|
|
1826
|
+
description: "解析JSON编码数据,返回JS对象。\n\n示例:\n\nDECODEJSON('{\\\"name\\\": \"amis\"}') 得到 {name: 'amis'}。",
|
|
1827
1827
|
example: "DECODEJSON('{\\\"name\\\": \"amis\"}')",
|
|
1828
1828
|
params: [
|
|
1829
1829
|
{
|
|
@@ -1840,7 +1840,7 @@ var doc = [
|
|
|
1840
1840
|
},
|
|
1841
1841
|
{
|
|
1842
1842
|
name: "GET",
|
|
1843
|
-
description: "根据对象或者数组的path路径获取值。 如果解析 value 是 undefined 会以 defaultValue
|
|
1843
|
+
description: "根据对象或者数组的path路径获取值。 如果解析 value 是 undefined 会以 defaultValue 取代。\n\n示例:\n\nGET([0, 2, {name: 'amis', age: 18}], 1) 得到 2,\nGET([0, 2, {name: 'amis', age: 18}], '2.name') 得到 'amis',\nGET({arr: [{name: 'amis', age: 18}]}, 'arr[0].name') 得到 'amis',\nGET({arr: [{name: 'amis', age: 18}]}, 'arr.0.name') 得到 'amis',\nGET({arr: [{name: 'amis', age: 18}]}, 'arr.1.name', 'not-found') 得到 'not-found'。",
|
|
1844
1844
|
example: "GET(arr, 2)",
|
|
1845
1845
|
params: [
|
|
1846
1846
|
{
|