利用内置数据集实现范围划分

文档创建者:admin
浏览次数:905
最后更新:2022-12-30
FineBI文档
FineBI文档: 构建图表和分析数据
1. 概述


1.1 问题描述

当我们希望在 FineReport 中根据数值区段对其进行等级划分时,例如根据销售员的销量范围,对销售员划分等级,如下表所示:
销量范围
等级
2000以上
A
1900~2000
B
1800~1900
C
1700~1800
D
1600~1700
E
1500~1600
F
1500以下
G
通常的做法是写 IF 公式一个一个范围的判断,导致公式冗长,嵌套复杂。那如何能简单快速的建立等级对应关系呢?



1.2 解决思路


利用内置数据集建立好范围与等级对应关系,再利用 tablename.select() 公式来查询。

2. 示例



2.1 数据准备

1)新建普通报表,新建数据库查询 ds1,SQL 查询语句为:SELECT 销售员,sum(销量) 销量 FROM 销量 group by 销售员。

2)新建内置数据集「范围划分」,设计三个字段分别为「最大值」、「最小值」和「等级」,设置表示范围值的两个列名的数据类型为整数或小数,再将对应数值和等级增加到字段中。如下图所示:



2.2 报表设计


1)将 ds1 中「销售员」「销量」数据列分别拖入 A2、B2 单元格,输入对应标题,设计表格样式如下图所示:
2)选中 C2 单元格,单击右键,选择「单元格元素>插入公式」,公式为: 范围划分.select(等级, B2 >= 最小值 && B2 < 最大值),即返回当前 B2 单元格在「范围划分」数据集中大于等于最小值并且小于最大值对应的等级。



2.3 效果预览2.3.1 PC 端


保存报表,点击「分页预览」,效果如下图所示:



2.3.2 移动端


App 和 HTML5 端均支持,效果如下图所示:
3. 模板下载


已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\SpecialSubject\利用内置数据集实现范围划分.cpt




发表评论已发布 2

qwert

发表于 2022-9-29 13:04:29 来自手机 | 显示全部楼层

测试.手机版树形导航,然后侧边栏导航就完美了
回复

使用道具 举报

qwert

发表于 2022-9-29 19:49:32 来自手机 | 显示全部楼层

qwert 发表于 2022-9-29 13:04
测试.手机版树形导航,然后侧边栏导航就完美了

测试呀,认同楼上观点
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则