1. 概述
1.1 版本
报表服务器版本 | 功能变更 |
---|---|
11.0 | - |
1.2 预期效果
在日期控件中选择年月,可查询到该月份下的天数和周。如下图所示:
1.3 实现思路
使用 RANGE 公式和 DAYSOFMONTH 获取该月的天数,并且使用控件的值拼接起来;
使用 SWITCH 和 WEEKDAY 公式获取该天是周几。
2. 示例
2.1 公式介绍
公式 | 备注 |
---|---|
DAYSOFMONTH($time+"01") | 获取日期控件的月份有多少天 |
RANGE(1, DAYSOFMONTH($time + "-01")) | 获取日期的第一天到最后一天的日期 |
$time + "-" + FORMAT(A1, "#00") | 将前面获取的天数和日期拼接 |
SWITCH(WEEKDAY($time + "-" + FORMAT(A1, "#00")), "1", "周一", "2", "周二", "3", "周三", "4", "周四", "5", "周五", "6", "周六", "0", "周日") | 用 WEEKDAY 公式获取当前天是周几,并且用 SWITCH 公式转成汉字展示 |
2.2 插入公式
在 FineReport 设计器中,点击「文件>新建普通报表」;
1)右击 A1 单元格,选择「单元格元素>插入公式」,公式为:RANGE(1, DAYSOFMONTH($time + "-01")) 。
2)右击 A2 单元格,选择「单元格元素>插入公式」,公式为:$time + "-" + FORMAT(A1, "#00") 。
3)右击 A3 单元格,选择「单元格元素>插入公式」,公式为:SWITCH(WEEKDAY($time + "-" + FORMAT(A1, "#00")), "1", "周一", "2", "周二", "3", "周三", "4", "周四", "5", "周五", "6", "周六", "0", "周日")。
将单元格内容居中显示,并为这三个单元格加上边框(边框自定义)。下图为 A1 单元格输入公式的步骤,A2 和 A3 单元格输入公式的步骤与之相同。如下图所示:
2.3 单元格属性
A1、A2、A3 单元格内容居中显示,并加上边框(边框自定义)。
左键选中 A1 单元格,在右侧属性面板中选择「单元格属性>扩展」,扩展方向选择「横向」扩展。如下图所示:
2.4 日期控件
进入该模板的参数面板,向参数面板中拖入「日期控件」和「查询按钮」;
「日期控件」的控件名称为 time ,控件值为 2019/10/01,格式选择 yyyy-MM 。如下图所示:
2.5 效果查看
保存模板,点击「填报预览」,效果如本文 1.2 节所示。
注:该方法不支持移动端。
注:表头下面不能放字符,否则分页会有错行的情况。
3. 模板下载
已完成的模板,请参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Primary\FreeReport\根据年月查询月份的天和周.cpt
点击下载模板:根据年月查询月份的天和周.cpt