SAP Crystal Reports:如何将小数为.00的折扣百分比转为整数
在SAP Crystal Reports中动态格式化discount percent字段:自动隐藏.00小数部分
我刚好之前在项目里处理过一模一样的需求,在Crystal Reports中可以通过自定义公式字段轻松实现这个动态显示的效果——当字段小数部分是.00时显示为整数,否则保留原有两位小数格式。具体操作步骤和公式如下:
步骤1:创建新的公式字段
- 打开报表的「字段资源管理器」(如果没显示可以按
Ctrl+Alt+F调出) - 右键点击「公式字段」,选择「新建」,给公式起个好记的名字,比如
Formatted Discount Percent - 在公式编辑器中粘贴下面的代码:
// 判断discount percent的小数部分是否为0 If Remainder({discount percent}, 1) = 0 Then // 小数部分为0时,转成无小数的整数格式 CStr({discount percent}, 0) Else // 小数部分非0时,保留两位小数 CStr({discount percent}, 2)
步骤2:替换原字段
把报表上原来的discount percent字段删除,然后从字段资源管理器中把刚创建的Formatted Discount Percent公式字段拖到对应的位置即可。
效果验证
针对你给出的示例输入,输出完全符合预期:
- 输入
50.00→ 输出50 - 输入
43.12→ 输出43.12 - 输入
60.40→ 输出60.40 - 输入
20.00→ 输出20 - 输入
13.00→ 输出13
亲测这个方法在Crystal Reports 2016、2020版本都能正常运行,如果你用的是更早的版本,只需要确保Remainder函数可用(这个函数在Crystal Reports 10及以后就支持了)。
内容的提问来源于stack exchange,提问作者Culascage




