将报表表单SSRS导出到Excel仅将小数添加到0.00值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将报表表单SSRS导出到Excel仅将小数添加到0.00值相关的知识,希望对你有一定的参考价值。

我有一个简单的Reporting Services报告,其中有几个来自存储过程的DECIMAL(19,4)值。我用“N2”格式化这些列,因为我总是想要2个小数。格式在报告中正常工作。但是,只要我将其导出到Excel,在其中一列(右边的最后一个,是否重要?)中,小数位数从2增加到15,但仅当单元格中的值为0时(原始格式为0.00,当然)。

如果单元格为空,则它变为空,即可。如果它与0不同,则显示正确。只有值0变为0.000000000000000

我也尝试了格式“0.00”,但问题仍然存在。

当我打开Excel时,它说它打开它有问题。具有这种奇怪的细胞都有绿色三角形信号错误。它说“此单元格中的数字格式为文本或前面有撇号”。无论我对这些值有什么看法,我认为我也在对同一列的所有其他值进行处理,因此我无法理解为什么0被区别对待。

如果我强制存储过程在返回0时返回1,则它可以正常工作。

[编辑]如果我在St.Proc强制演员到DECIMAL(19,4)。对于这个值(来自算术计算),它工作!

所以我已经解决了我的问题,但我仍然想知道为什么并删除一个可怕的用途CAST顺便说一句,我投射到十进制的代码基本上是:

CASE WHEN B = 0 THEN NULL ELSE 100.0*A/B END 

A和B DECIMAL(19,4)。只有当A = 0时才会出现问题。

答案

在Tablix中,按如下方式编写表达式

=CDbl(Fields!YourFeild.Value)

然后转到文本框属性>数字,并在类别编号和小数位下选择。现在,如果将其导出到Excel,您将获得所需的结果。您总是需要这两者的组合才能在Excel中获取格式。

以上是关于将报表表单SSRS导出到Excel仅将小数添加到0.00值的主要内容,如果未能解决你的问题,请参考以下文章

ssrs报告导出到excel - 损坏的超链接

SSRS导出冻结条件格式

如何使用jQuery仅将可见的tr表导出到excel

poi生成excel报表小数点前面的0不显示怎么解决

报告正文中的SSRS日历控件

用C#访问SSRS自动导出SSRS报表