历史版本10 :将日期型转化为中文形式 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 问题描述

因政府、事业单位的正式文件中的落款日期都是中文的。

如:在 FineReport 中制作填报模板,使用了日期控件,希望在做填报时,将当前日期控件中选择的日期值(FR 中默认是yyyy-MM-dd的日期格式),能够以中文的方式输出显示,然后再入库,但入库的数据还是默认的数值型的 yyyy-MM-dd 的日期格式。

实现效果如下图:

222

1.2 解决思路

使用 NUMTO() 函数,通过字符转化方式,将其转化为中文输出即可。

NUMTO(number,bool):返回 number 的中文表示。

注:其中 bool 用于选择中文表示的方式,当没有 bool 时,采用默认方式(false)显示。

  • 示例:NUMTO(2345,true) 返回值为二三四五

  • 示例:NUMTO(2345,false) 返回值为二千三百四十五

  • 示例:NUMTO(2345) 返回值为二千三百四十五

2. 示例编辑

2.1 控件设置

新建一张普通报表,右击任意单元格,选择「控件设置」,选择控件为日期控件,格式为 yyyy-MM-dd。如下:

222

2.2 属性设置

再右击此单元格,选择「形态>公式形态」,输入公式:REPLACE(NUMTO(YEAR($$$), true), "零", "〇") + "年" + NUMTO(MONTH($$$), false) + "月" + NUMTO(DAY($$$), false) + "日"

222

公式解释:REPLACE(NUMTO(YEAR($$$),true),"零","〇"),表示将其中输出的中文的零替换为特殊字符 〇。REPLACE 函数的具体使用,可参见 文本函数

2.3 效果预览

2.3.1 PC 端

保存模板后,选择填报预览。

在日期控件中选择好日期后,点击其他处,显示效果如上图所示。

注:有些日期的中文形式还想含有星期,公式如下所示。

2.3.2 移动端

App 与 HTML5 端效果相同,如下图所示:

3. 模板下载编辑