跳到主要内容

报表公式

1. 使用场景

有时候,原始表单中的数据,我们需要经过一些自定义的处理之后才能展示。

例如:

  • 表单中的数据是每个员工填写的,而报表中希望展示每天填写表单的员工人数,这个就需要使用到 COUNT()函数计算之后作为结果来进行展示了
  • 用户希望在表单中新增一些自定义的字段,然后通过这些字段关联超链接来做页面跳转,这样的需求也可以使用到这里的自定义公式字段的功能

为了实现上述需求,我们需要先来了解一下,目前宜搭平台对于报表都提供了哪些公式,主要分为下面两大类:

  • 逻辑判断类
  • 字符串处理类
  • 聚合类
  • 数组类

2. 报表公式视频讲解

3. 设置公式入口

路径:新建报表 >> 报表设计页 >> 选择数据集 >> 选择显示列字段 >> FX >> 设置对应公式即可

查看以下视频进行设置:

4. 逻辑判断类

4.1 条件判断

标识符

含义

!=

不等于,用于判断字段不等于某个值

4.2 空值判断

标识符

含义

IS NULL

为空

IS NOT NULL

不为空

4.3 逻辑判断

标识符

含义

示例

AND

CASEWHEN(组件1="西瓜" AND 组件2="西瓜",1,2) 组件1、组件2同时等于西瓜时返回值1,否则返回值2

OR

CASEWHEN(组件1="西瓜" OR 组件2="桃子",1,2) 组件1和组件2任意一个时返回值1,否则返回值2

NOT

不等于

CASEWHEN(NOT(组件1="西瓜") ,1,2) 组件1不等于西瓜就返回值1,否则返回值2

5. 字符串处理类

LEN

用法:LEN([字符串字段]),函数返回为字符串的长度

示例:LEN("test"),返回值为4;LEN("测试"),返回值为2,一个中文对应1个英文字符。

LEFT

用法: LEFT(<度量字段>,< n >), 函数返回<字段>值从左边第1个字符开始,长度为n的字符串

示例: LEFT(字段1,3) 返回值为"ABC";字段1的值为"ABCDEF";

RIGHT

用法: RIGHT(<度量字段>,< n >), 函数返回<字段>值从右往左数的长度为n的字符串

示例:RIGHT(字段1,3) 返回值为"DEF";字段1的值为"ABCDEF";

MID

用法:MID(<度量字段>, < start >, < n >), 函数返回<字段>值从从左边第start个开始, 长度为n的字符串

示例:MID(字段1, 3, 3) 返回值为"CDE";字段1的值为"ABCDEF";

POS

用法:POS(<度量字段>,<字串>), 函数返回<字串>在<文本>中的位置, 如无匹配则返回0;

示例:POS(字段1,"DE") 返回值为4;字段1的值为"ABCDEF";

UPPER

用法:UPPER(<度量字段>), 将<字段>的值转换成大写;

示例:UPPER(字段1) 返回值为"ABCDEF";字段1的值为"AbcdeF";

LOWER

用法:LOWER(<度量字段>), 将<字段>的值转换成小写;

示例:LOWER(字段1) 返回值为"abcdef";字段1的值为"AbcdeF";

VAL

用法:VAL(<度量字段>), 将<字段>文本类型转换成数值类型

示例:VAL(字段1) 返回值为 123;字段1的值为"123";

LEFTTRIM

用法:LEFTTRIM(<度量字段>), 去掉<字段>左边的空格后返回

示例:LEFTTRIM(字段1) 返回值为"ABC";字段1的值为" ABC";

RIGHTTRIM

用法:RIGHTTRIM(<度量字段>), 去掉<字段>右边的空格后返回

示例:RIGTTRIM(字段1) 返回值为"ABC";字段1的值为"ABC ";

NUMBERTOSTRING

用法:NUMBERTOSTRING(<数值>), 数值类型的数据转换成字符串

示例:NUMBERTOSTRING(字段1) 返回值为"12345";字段1的值为"12345 ";

SPLITPART

用法:SPLITPART(<字符串字段>,分隔字符,子串位置), 公式会将一个字符串按照“分隔字符”将其分为N个子串(N等于分隔字符的数量+1),子串位置从1(从左往右)开始计数,或者从-1(从右往左)开始计数

示例:SPLITPART(<字段1>,A,2) 返回值为"BCD";字段1的值为"ABCDABHABC";子串位置填写-5时,也可以取到"BCD"

CONCAT

用法:CONCAT(<字段>,<字段>,.....), 公式会将多个字段连接为一个字符串。入参必须为字符串类型的字段

示例:CONCAT(<字段1>,<字段2>) 返回值为"ABCD";字段1的值为"A",字段2的值为"BCD"

REPLACE

用法REPLACE([字符串], [搜索字符串], [替换字符串]), 函数返回为替换后的字符串

示例:REPLACE([字段1], [字段2], [字段3])返回值为"a12345efg";字段1的值为"abcdefg",字段2的值为""bcd",字段3的值为"12345".

ROUND

用法:ROUND(<字段>,<精度>), 四舍五入地对字段进行小数位数调整

示例:ROUND(<字段1>,<精度>) 返回值为"12.33";字段1的值为"12.33333",精度为2

MOD

用法:MOD(<字段>,<字段>), 取模(取余)运算,返回取模值(或余数)。

说明:若要获得除法的商,可使用/ 四则运算符,比如 6/4 得到 商1余2。

示例: MOD(<字段1>,<字段2>) 字段1的值为"6",字段2的值为"4",返回值为"2";

CASEWHEN

用法1:CASEWHEN(<条件>,<值>,<条件>,<值>.....), 类同SQL中的case when语法

示例:CASEWHEN(<性别字段>="男","male",<性别字段>="女","female"),则该字段值为"男"的被替换为"male","女"替换为"female"

用法2:CASEWHEN(<条件>,<值>,<条件>,<值>.....<值>), 类同SQL中的case when语法

示例:CASEWHEN(<性别字段>="男","male","female"),则该字段值为"男"的被替换为"male",非"男"替换为"female"

STRINGTODATE

用法:STRINGTODATE(<字段>,<格式>), 字符串转时间

示例:STRINGTODATE("1989-09-27","yyyy-MM")返回值为"198909"

以上两个函数的format格式目前统一为java 中格式化保持一致,支持格式类型如下:

yyyy:年

MM:月

dd:日

hh:1~12小时制(1-12)

HH:24小时制(0-23)

mm:分

ss:秒

TODAY(可视化图表专用)

用法:TODAY(),获取当天日期

示例:

NOW

用法:NOW(),获取当前时间,会精确到秒

示例:

DATEADD

用法:DATEADD(<时间字段>,<偏移量>,<时间粒度>),在<时间字段>的基础上增加<时间粒度>的<偏移量>。

  • 时间粒度取值:
    • YEAR:年
    • MONTH:月
    • DAY:日
    • HOUR:时
    • MINUTE:分
    • SECOND:秒
  • 偏移量是需要增加或减少的具体数字,取值为正则表示增加,取值为负则表示减少。

示例1:

假设表单中日期组件的取值为"20200901",那么DATEADD(日期组件,10,"DAY") = 20200911

示例2:

假设表单中日期组件的取值为"20200901",那么DATEADD(日期控件,-1,"DAY") = 20200831

日期展示格式默认为yyyyMMdd,如需需要修改日期的展示格式可以参考DATEFORMAT函数的示例。

DATEDIFF

用法:DATEDIFF(<时间字段1>,<时间字段2>,<时间粒度>),返回的结果为时间段字段1减去时间段字段2在时间粒度上的差值。

时间粒度可选值为:

  • YEAR       年
  • MONTH    月
  • DAY        日
  • HOUR      时
  • MINUTE   分
  • SECOND  秒

示例:DATEDIFF(日期组件1,日期组件2,"DAY"),返回值为2个日期组件相差天数

注意:参数仅支持日期组件,无法在公式输入固定日期值。

假设表单中日期控件的日期值为“2020-02-14”,假设今天为“2020-02-16”,那么使用

DATEDIFF(NOW(),填写日期,"DAY") = 2

DATEDIFF(填写日期,NOW(),"DAY") = -2

DATEFORMAT

用法:DATEFORMAT(<日期字段>,<时间格式>),将日期格式化成字符串

以上两个函数的format格式目前统一为java 中格式化保持一致,支持格式类型如下:

  • yyyy:年
  • MM:月
  • dd:日
  • hh:1~12小时制(1-12)
  • HH:24小时制(0-23)
  • mm:分
  • ss:秒

示例1:

DATEFORMAT(<日期字段>,"yyyy-MM-dd"),若日期字段有个值为1989年8月4日,则返回值为1989-08-04,格式化时,也可以将"-"改为"/"等字符。

示例2:

DATEFORMAT(<日期字段>,"yyyy-MM-dd HH:mm:ss"),若日期字段有个值为2020年9月1日下午1点30分整,则返回值为2020-09-01 13:30:00,格式化时,也可以将连接符号"-"、“:”改为"/"、“年”、“月”、“日”等字符。

FROMUNIXTIME

用法:将数字型的unix时间日期值unixtime转为日期值

函数声明:

datetime fromunixtime(bigint unixtime)

参数说明:

  • unixtime:Bigint类型,秒数,unix格式的日期时间值,若输入为string,double,decimal类型会隐式转换为bigint后参与运算。
  • 返回值:Datetime类型的日期值,unixtime为NULL时返回NULL。

示例:

fromunixtime(123456789) = 1973-11-30 05:33:09

WEEK

用法WEEK([日期], [起始日(可以不指定)]), 计算日期年份中的哪一周, 起始日不指定,默认一周的第一天是周一,起始日的值为:1-7 分别表示周一为第一天.... 周日为第一天

示例:WEEK([日期],)返回值为"20202";字段的值为"2020-01-08",起始日可以不指定,默认为空。

QUARTER

用法QUARTER([日期], [是否是财年(可以不指定)]), 计算日期年份中的哪一季度, 是否是财年:1表示按照财年统计(4月份), 0表示按照自然年

示例:QUARTER([字段1], 0)返回值为"1";字段1的值为"2020-02-02"

新增本文处理类报表公式 STRINGTONUMBER(),该公式用于将文本类型的数字,转换成数值类型。

该公式目前仅支持报表页面使用,使用公式语法如下:

// 字段为文本类型的数字。
STRINGTONUMBER<字段>)

6. 聚合类

为了便于演示聚合类字段的使用效果,这里以一个实际的案例来辅助介绍

首先,假设我们通过多个表单收集到了如下的两个数据集「示例数据集1」和「示例数据集2」

示例数据集1

数据集

BU

部门

预算类型

费用

xxpt

协同

团建费

500

xxpt

协同

培训费

200

xxpt

IT

团建费

700

xxpt

IT

培训费

150

aliyun

飞天1

团建费

200

aliyun

飞天1

培训费

100

表格

BU

部门

部门总费用

xxpt

协同

700

xxpt

IT

850

aliyun

飞天1

300

示例数据集2

数据集

BU

部门

预算类型

费用

xxpt

协同

团建费

500

xxpt

协同

培训费

200

xxpt

协同

团建费

500

xxpt

协同

培训费

200

xxpt

IT

团建费

700

xxpt

IT

培训费

150

xxpt

eHR

培训费

0

xxpt

eHR

团建费

0

aliyun

飞天1

团建费

200

aliyun

飞天1

培训费

100

表格

BU

部门

预算类型

xxpt

协同

团建费

xxpt

协同

培训费

xxpt

IT

团建费

xxpt

IT

培训费

xxpt

eHR

培训费

xxpt

eHR

团建费

aliyun

飞天1

团建费

aliyun

飞天1

培训费

SUM

用法:SUM (<度量字段>,[条件],[排除字段]) 返回合乎[条件]下, 对<字段>进行求和的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集1

部门团建费 =SUM (费用, 预算类型="团建费") :

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

表格结果

BU

部门

部门总费用

部门团建费

xxpt

协同

700

500

xxpt

IT

850

700

aliyun

飞天1

300

200

BU 团建费= SUM (费用, 预算类型="团建费", 部门) :

表格结果

BU

部门

部门总费用

部门团建费

BU团建费

xxpt

协同

700

500

1200

xxpt

IT

850

700

1200

aliyun

飞天1

300

200

200

AVG

用法:AVG(<度量字段>,[条件],[排除字段])

用法介绍:返回合乎[条件]下, 对<字段>进行求平均的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集1

  • 计算每个BU下的平均团建费

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

如果要计算平均团建费用,需要将预算类型为团建费的数据费用进行计算,因此选择 费用字段 <度量字段> ,配置 预算类型="团建费" [条件] ,由于每个BU下有多个部门,而我们不考虑部门情况,只需要计算每个BU下的平均团建费,因此需要将 部门字段 作为 [排除字段]

公式如下:BU平均团建费=AVG(费用, 预算类型="团建费",部门):

表格结果:

BU

部门

部门总费用

部门平均团建费

xxpt

协同

700

600

xxpt

IT

850

600

aliyun

飞天1

300

200

  • 计算总平均团建费用

如果要计算平均团建费用,需要将预算类型为团建费的数据费用进行计算,因此选择 费用字段 <度量字段> ,配置 预算类型="团建费" [条件] 。由于计算总平均团建费用,需要将所有部门的团建费加起来计算,不需要考虑BU以及部门情况,因此需要将 部门字段及BU字段 均作为 [排除字段]

公式如下:所有部门平均团建费=AVG(费用, 预算类型='团建费',部门,BU) :

表格结果:

BU

部门

部门总费用

部门平均团建费

所有平均团建费

xxpt

协同

700

600

466.67

xxpt

IT

850

600

466.67

aliyun

飞天1

300

200

466.67

MAX

用法:MAX(<度量字段>,[条件],[排除字段])返回合乎[条件]下, 对<字段>求最大值的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集1

部门最高团建费=MAX(费用, 预算类型='团建费') :

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

表格结果

BU

部门

部门总费用

部门最高团建费

xxpt

协同

700

500

xxpt

IT

850

700

aliyun

飞天1

300

200

BU最高团建费=MAX(费用, 预算类型="团建费", 部门) :

表格结果

BU

部门

部门总费用

部门平均团建费

BU最高团建费

xxpt

协同

700

600

700

xxpt

IT

850

600

700

aliyun

飞天1

300

200

200

MIN

用法:MIN(<度量字段>,[条件],[排除字段])返回合乎[条件]下, 对<字段>求最小值的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集1

部门最低团建费=MIN(费用, 预算类型="团建费") :

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

表格结果

BU

部门

部门总费用

部门最低团建费

xxpt

协同

700

500

xxpt

IT

850

700

aliyun

飞天1

300

200

BU最低团建费=MIN(费用, 预算类型="团建费", 部门) :

表格结果

BU

部门

部门总费用

部门平均团建费

BU最低团建费

xxpt

协同

700

600

500

xxpt

IT

850

600

500

aliyun

飞天1

300

200

200

COUNTDISTINCT

用法:COUNTDISTINCT(<度量字段>,[条件],[排除字段])返回合乎[条件]下, 对<字段>进行去重计数的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集2

BU 部门数量 = COUNTDISTINCT(部门, 费用>0,预算类型)

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

表格结果

BU

部门

预算类型

BU部门数量

xxpt

协同

团建费

1

xxpt

协同

培训费

1

xxpt

IT

团建费

1

xxpt

IT

培训费

1

aliyun

飞天1

团建费

1

aliyun

飞天1

培训费

1

COUNT

用法:COUNT(<度量字段>,[条件],[排除字段])返回合乎[条件]下, 对<字段>进行计数的结果, [排除字段] 不参与求和的交叉计算;

示例:使用示例数据集2

部门预算条数 = COUNT(部门, 费用>0,预算类型)

注意:

目前报表类聚合函数暂不支持进行逻辑运算。

表格结果

BU

部门

预算类型

BU部门数量

xxpt

协同

团建费

4

xxpt

协同

培训费

4

xxpt

IT

团建费

2

xxpt

IT

培训费

2

aliyun

飞天1

团建费

2

aliyun

飞天1

培训费

2

7. 数组类

ArrayToString

用法ArrayToString(<数组字段>,[分隔符可选]),将数组转换为字符串

示例:ArrayToString(<多选等数组字段>,<分隔符>) 返回值为"产品部-技术部-业务部";字段1的值为"部门",字段2的值为"-"

StringToArray

用法StringToArray(<数组字段>,[分隔符可选]),将字符串解析为数组

示例:StringToArray(<多选等数组字段>,<分隔符>) 返回值为"产品部,技术部,业务部";字段的值为"产品部-技术部-业务部",字段2的值为"-"

ArrayLength

用法ArrayLength(<数组字段>),返回数组长度

示例:ArrayLength(<多选等数组字段>)返回值为"3";字段的值为"部门",其选项为"产品部,技术部,业务部"

ArrayCat

用法ArrayCat(<数组字段1>,<数组字段2>,...),返回多数组拼接格式

示例:ArrayCat(<多选等数组字段1>,<多选等数组字段2>,...)返回值为"产品部,技术部,业务部,产品人员,技术人员,业务人员";字段1的值为"产品部,技术部,业务部",字段2的值为"产品人员,技术人员,业务人员"

8. 常见问题

8.1 在报表中 COUNT() 怎么使用呢?

COUNT 是进行计数的函数,请查看以下视频的详细讲解

8.2 为什么报表提醒:公式解析异常。详细内容:AST语法异常:SQL翻译时遇到未支持的数据库类型:11

目前报表公式字段只能使用当前文档已有的函数公式,若使用文档以外的函数公式就会进行报错,报错提示截图如下:

8.3 CASEWHEN函数中判断组件为空不生效

当前公式内进行数据为空判断时,仅支持数据 IS NULL的写法,数据=""的写法不支持。

Copyright © 2025钉钉(中国)信息技术有限公司和/或其关联公司浙ICP备18037475号-4