Crystal Reports中的小数点/逗号问题

2020-08-19 18:07发布

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


我正在Crystal Reports的命令协议中调用一个函数。 它没有给出正确的字符串,因为输出是varchar2。 问题是小数点处理。

Crystal Reports(带有OraClient12Home的2016 SP7)似乎不使用操作系统(英语(英语),Windows 7)的区域(语言/国家)设置。

当我在命令中使用以下命令时:

从DUAL中选择TO_CHAR(5/2)

结果为:2.5,但必须为2.5。

我什至在Crystal Reports中将"产品区域设置"和"首选查看区域设置"设置为英语,但似乎无济于事。 Oracle Database NLS设置也正确(英国)。

亲切的问候,

Scubapro66。

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


我正在Crystal Reports的命令协议中调用一个函数。 它没有给出正确的字符串,因为输出是varchar2。 问题是小数点处理。

Crystal Reports(带有OraClient12Home的2016 SP7)似乎不使用操作系统(英语(英语),Windows 7)的区域(语言/国家)设置。

当我在命令中使用以下命令时:

从DUAL中选择TO_CHAR(5/2)

结果为:2.5,但必须为2.5。

我什至在Crystal Reports中将"产品区域设置"和"首选查看区域设置"设置为英语,但似乎无济于事。 Oracle Database NLS设置也正确(英国)。

亲切的问候,

Scubapro66。

付费偷看设置
发送
4条回答
暮风yp
1楼-- · 2020-08-19 18:42

CStr对Oracle无效。

您遇到的问题是Oracle问题,而不是Crystal问题,因为您正在将数字转换为数据库中而不是报表中的字符串。

因此 ,您有两种选择:

1。 从数据库返回一个数字,而不将其转换为字符串。 然后,Crystal将根据其设置格式化数字。

2。 将格式字符串与To_Char(field,format)一起使用。 您可以在此处找到有关有效格式字符串的信息。

-Dell

Tong__Ming
2楼-- · 2020-08-19 19:07

是否可以选择函数正在使用的字段,并以公式或SQL表达式在报表中进行计算,而不是使用 数据库?

如果问题仅在于逗号应为句点,则还可以执行以下操作:

 Replace({my field},',','。')  

这会将逗号替换为句点。 但是,如果Oracle函数未返回正确的数字,它不会给您带来不同的结果。

-Dell

Violet凡
3楼-- · 2020-08-19 18:42

亲爱的Marc

您可以在Crystal中尝试使用以下任一公式来解决数字格式问题。

 CStr(您的变量,"#,##,##,##,##,###  .00")

 totext({yourvariable},2,"")
 

问候

Venkat

SAP小黑
4楼-- · 2020-08-19 18:51

嗨,Venkat

感谢您的回答。

不幸的是,这没有用。

例如,我返回" 0,10 mmol/l",而应该是" 9.90 mmol-l"。

-马克。

一周热门 更多>